C++ vector容器 循循环使用 完成数据清空,回收空间.
2012-03-23 10:38
561 查看
办法1:使用clear,清空元素,但不回收空间.
j=vecInt.capacity();//j=512
i=vecInt.size();//i=0
方法2:使用erase循环删除,结果同上.
for(;iter!=vecInt.end();)
{
iter=vecInt.erase(iter);
}
j=vecInt.capacity();//j=512
i=vecInt.size();//i=0
erase在每次操作时,迭代器指针会整体前移1,就是每次都会“搬”全部数据,所以vector不适合做频繁删除的容器.
方法3:使用clear和swap.
先使用vecInt.clear()清空,再使用swap,释放空间回收内存.
(先vec.clear()再vec->swap((std::vector<temp>)(vec)),就能实现清空vector和释放原来vector的内存)
//vecInt.swap(vector<int>());//另一种写法
j=vecInt.capacity();//j=0
i=vecInt.size();//i=0
该语句是由vector<int>(vecInt).swap(vecInt)的变体而来.
以下解释引自CSDN:
std::vector<T>(v).swap(v);的作用相当于:
{
std::vector<T>temp(v);//1产生一个和v内容一模一样的vector,只不过temp的容量是恰好满足其大小
temp.swap(v);//2把v和temp交换
}
第一句产生一个和v内容一模一样的vector,只不过temp的容量是恰好满足其大小的
第二句把v和temp交换
然后temp就自动解析掉了
这样写的作用是:把v的容量缩小到最佳值
该例中执行这句时,capacity收缩到500,若要收缩到0,需要先clear数据,再swap.
××××××××××××××××××××××
不过以上还是调用stl的函数看到的,不知其内部是如何做的。在网上看到其他人的讨论有这样:
@@而Cygwin中的GCC用的应该是HPSTL或从它继承来的SGISTL,对于小内存有一种缓冲池机制,一旦进池的内存就再也不会交还给系统了
@@swap不起作用,因为原因是allocator.
from:http://blog.csdn.net/metalkittie/archive/2008/10/21/3115750.aspx
注意clear不会自动调用vector中的成员的析构函数,指针数据的内存需要自己来释放。
相关文章推荐
- C++ vector容器 循环使用 完成数据清空,回收空间
- C++ vector容器使用 排序
- 【语言-C++】C++容器:list、vector、hash、map的区别及使用范围
- map,vector 等容器内容的循环删除问题(C++)
- C++文本查询程序 不要定义类和智能指针管理数据 C++Primer练习12.28 使用vector,map,set容器保存来自文件的数据并生成查询结果
- C++文本查询程序 C++Primer练习12.28 使用vector,map,set容器保存来自文件的数据并生成查询结果
- 【C++】vector容器和list容器中使用单个迭代器的erase函数学习笔记
- C++文本查询程序 不要定义类和智能指针管理数据 C++Primer练习12.28 使用vector,map,set容器保存来自文件的数据并生成查询结果
- C++文本查询程序 C++Primer练习12.28 使用vector,map,set容器保存来自文件的数据并生成查询结果
- vector容器的使用(部分)示例(c++)
- C++面试题:看代码找错—vector容器的使用
- C++ STL vector(向量容器)的使用(附完整程序代码)
- C++文本查询程序 不要定义类和智能指针管理数据 C++Primer练习12.28 使用vector,map,set容器保存来自文件的数据并生成查询结果
- c++编写无向图 使用容器Vector编写邻接表法
- C++存储数据结构List、CArray、Vector和Map使用分析
- C++文本查询程序 C++Primer练习12.28 使用vector,map,set容器保存来自文件的数据并生成查询结果
- C++中在容器Vector中使用结构体Struct
- C++使用vector时,预先分配空间大小可以提高速度
- c++容器(vector|map)中使用函数指针
- C++文本查询程序 不要定义类和智能指针管理数据 C++Primer练习12.28 使用vector,map,set容器保存来自文件的数据并生成查询结果