vector,clear()并不真正释放内存(这是为优化效率所做的事),clear实际所做的是为vector中所保存的所有对象调用析构函数(如果有的话),然后初始化size这些东西,让觉得把所有的对象清除了。 真正释放内存是在vector的析构函数里进行的,所以一旦超出vector的作用域(如函数返回),首先它所保存的所有对象会被析构,然后会...
vector.clear()不能用来清零 vector.clear()函数并不会把所有元素清零,笔者就曾经这样幻想过这个函数的作用,然而事实证明并不是。 vector有两个参数,一个是size,表示当前vector容器内存储的元素个数,一个是capacity,表示当前vector在内存中申请的这片区域所能容纳的元素个数。 通常capacity会比size大,如果往vector中...
vector内的元素如果是对象型会在clear时调用对应的析构,如果是指针型,vector并不负责释放 内存,这个会引起真正的内存泄露。 如果你想回收vector的内存,那么可以用swap技法,比如vector<type> tmp.swap(v) 。这将生成一个空的vector,然后与现有的 vector交换。
并不是所有的STL容器的clear成员的行为都和vector一样。事实上,其他容器的clear成员都会释放其内存。比如另一个和vector类似的顺序容器deque, 观察上面程序的行为,会发现程序在stage two的内存占用也是寥寥的了。 另外,值得一提的是vector具有reserve成员,会提前为容器预留一定的空间,以防止后的push_back操作导致频繁地...
v.clear(); v.shrink_to_fit(); cout<<"after swap size:"<< v.size() <<endl; cout<<"after swap capacity:"<< v.capacity() <<endl;return0; }//输出:size:5capacity:6after swap size:0after swap capacity:0所以 不用以为只有swap替代clear才能正确释放vector的内存,C++11推出了shrink_to_fit...
1.clear只是将容器内数据标记为不再使用,但容器申请的内存不会释放(考虑到性能问题)。但是标记不使用...
通过测试我们发现,erase和clear只能将vector空间的元素给析构掉,并不能减少vector内存的占用。 这是侯捷老师《STL源码剖析》对vector的erase、clear函数实现介绍。这也进一步证实了erase、clear并不能释放vector的空间。 3、data函数可以返回vector元素存放的位置 ...
vector的clear会释放动态内存吗 vector没有提供释放内存的功能,只能申请 只有等到该vector的作用域结束时,才会自动释放内存 即使采用clear清空vector,其内部操作,也只是把数组长度设为0,而之前申请的内存是存在的。
不行,clear只是把那些元素全部删除掉,并不是释放内存。再者,你这样的定义容器是不需要释放内存的,如果你这样定义,std::vector <temp> *pVec。就需要了。先pVec->clear()再 pVec->swap( (std::vector <temp>)(*pVec) )。就能实现内存的释放。