C++中vector<int>和vector<int*>的区别
2014-03-09 09:13
966 查看
在使用STL容器(比如map、list、vector等)的时候,是用放一个对象还是放一个对象指针,即是用vector<int>还是vector<int*>,这里的vector可以换成其他的容器,int可以换成其他基本类型,也可以自定义的数据结构或类。
首先,要说明的是,这两种方式,怎么用都可以实现功能,把一组整型数放到容器里。先看看两种方式在使用的时候的区别。
1.vector<int>
[cpp] view
plaincopy
vector<int> vecTemp;
for (int i=0; i< 10; i++)
{
vecTemp.push_back(i);
}
这种方式不需要动态new内存,当然也不用delete。
2.vector<int*>
[cpp] view
plaincopy
vector<int*> vecTemp;
for (int i=0; i< 10; i++)
{
int* nTemp = new int;
nTemp = &i;
vecTemp.push_back(i);
}
这种方式采用new,当然也要用delete:
[cpp] view
plaincopy
std::vector<int*>::iterator Iter;
for(Iter=vecTemp.begin(); Iter!=vecTemp.end(); Iter++)
{
int* temp = *Iter;
delete temp;
temp = NULL;
}
3.两种用法的区别:
1)vector<int>不需要动态操作内存,不用担心内存泄露等问题;vector<int*>要注意new和delete成对使用。
2)当int改变成其他类型或结构或类的时候,用vector<int*>这种方式比较方便,容器里放的内容占用的内存也相对要少一些,指针在用的时候,去申请空间,不用,那就是个占用4个字节的地址。
原创链接:http://blog.csdn.net/wujunokay/article/details/12380341
首先,要说明的是,这两种方式,怎么用都可以实现功能,把一组整型数放到容器里。先看看两种方式在使用的时候的区别。
1.vector<int>
[cpp] view
plaincopy
vector<int> vecTemp;
for (int i=0; i< 10; i++)
{
vecTemp.push_back(i);
}
这种方式不需要动态new内存,当然也不用delete。
2.vector<int*>
[cpp] view
plaincopy
vector<int*> vecTemp;
for (int i=0; i< 10; i++)
{
int* nTemp = new int;
nTemp = &i;
vecTemp.push_back(i);
}
这种方式采用new,当然也要用delete:
[cpp] view
plaincopy
std::vector<int*>::iterator Iter;
for(Iter=vecTemp.begin(); Iter!=vecTemp.end(); Iter++)
{
int* temp = *Iter;
delete temp;
temp = NULL;
}
3.两种用法的区别:
1)vector<int>不需要动态操作内存,不用担心内存泄露等问题;vector<int*>要注意new和delete成对使用。
2)当int改变成其他类型或结构或类的时候,用vector<int*>这种方式比较方便,容器里放的内容占用的内存也相对要少一些,指针在用的时候,去申请空间,不用,那就是个占用4个字节的地址。
原创链接:http://blog.csdn.net/wujunokay/article/details/12380341
相关文章推荐
- C++中map<int,vector<int>>的初始化和访问方法
- c++中vector<int>和vector<int*>的用法区别
- c++中vector<int>和vector<int*>的用法比较
- 不允许使用“{...}”对”std::vector<int,std::allocator<int> >“类型的对象进行初始化
- priority_queue<int,vector<int>,greater<int>>优先队列,按照从小到大
- priority_queue<int,vector<int>,greater<int>>优先队列 按照由小到大顺序
- c++ vector<vector<int>>b(a[0].size(),vector<int>(a.size()))
- vector<pair<int,int> >的插入排序,字符串中子字符串个数查找
- c++ 中 const_iterator 和 const vector<>::iterator的区别
- 编写函数,接受一对指向vector<int>的迭代器和一个int值。在两个迭代器指定的范围内查找给定的值,返回一个布尔值来指出是否找到。
- 【priority_queue<int,vector<int>,greater<int>>优先队列 按照由小到大顺序】
- priority_queue<int,vector<int>,greater<int>>优先队列 按照由小到大顺序
- int、string、vector<int>的转换
- vector<int>G[] 和 vector<vector<int> G 的区别
- C++中 vector<vector<int>>
- vector<int>::iterator和vector<int*>::iterator还有vector<int>*的区别
- C++中vector<> resize()和reserve区别
- priority_queue<int,vector<int>,greater<int>>优先队列 按照由小到大顺序
- #碰到的小问题#c++中vector<int> 和vector<int>::iterator有什么不同
- const vector<int>::iterator和vector<int>::const_iterator的区别