马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
×
vector 中的内建有内存管理,当 vector 离开它的生存期的时候,它的析构函数会把 vector 中的元素销毁,并释放它们所占用的空间,所以用 vector 一般不用显式释放 —— 不过,如果你 vector 中存放的是指针,那么当 vector 销毁时,那些指针指向的对象不会被销毁,那些内存不会被释放。 vector的工作原理是系统预先分配一块CAPACITY大小的空间,当插入的数据超过这个空间的时候,这块空间会让某种方式扩展,但是你删除数据的时候,它却不会缩小。
vector为了防止大量分配连续内存的开销,
保持一块默认的尺寸的内存,clear只是清数据了
未清内存,因为vector的capacity容量未变化,系统维护一个的默认值
有什么方法可以释放掉vector中占用的全部内存呢?
标准的解决方法如下
template < class T >
void ClearVector( vector< T >& vt )
{
vector< T > vtTemp;
veTemp.swap( vt );
} 举例1: vector<int> vec(100);
cout << vec.capacity() << endl;
vector<int>().swap(vec); ////////////////////////////
cout << vec.capacity() << endl; 举例2: std::vector<int> v(1024*1024);
v.resize(12);
{
std::vector<int> tmp = v;
v.swap(tmp);
}
没看懂这可以释放内存
vector<int>().swap(v);
或者
{
std::vector<int> tmp = v;
v.swap(tmp);
} 利用vector释放指针 #include <vector>
using namespace std;
vector<void *> v;
每次new 之后调用v.push_back()该指针,
在程序退出时或其它你认为适当的时候,执行如下代码:
for (vector<void *>::iterator it = g_vPtrManager.begin(); it != g_vPtrManager.end(); it ++)
{
if (NULL != *it)
{
delete *it;
*it = NULL;
}
}
v.clear();
remark:若你的程序是多线程的,注意一下线程安全问题,必要时加个临界区控制一下。 总结: vector与deque不同,其内存占用空间只会增长,不会减小。比如你首先分配了10,000个字节,然后erase掉后面9,999个,则虽然有效元素只有一个,但是内存占用仍为10,000个。所有空间在vector析构时回收。 empty()是用来检测容器是否为空的,clear()可以清空所有元素。但是即使clear(),所占用的内存空间依然如故。如果你需要空间动态缩小,可以考虑使用deque。如果非要用vector,这里有一个办法: 在《effective STL》和其实很多C++文章中都有指明,用clear()无法保证内存回收。但是swap技法可以。具体方法如下所示:
vector<int> nums;
nums.push_back(1);nums.push_back(1);nums.push_back(2);nums.push_back(2);
vector<int>().swap(nums);//或者nums.swap(vector<int>()); vector<int>().swap(nums); 或者如下所示 加一对大括号都可以,意思一样的:
{
std::vector<int> tmp = nums;
nums.swap(tmp);
}
加一对大括号是可以让tmp退出{}的时候自动析构 swap技法就是通过交换函数swap(),使得vector离开其自身的作用域,从而强制释放vector所占的内存空间
|