vector内存释放 c++
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vector内存释放 c++相关的知识,希望对你有一定的参考价值。
main()
vector<double>it;
double a[100000];
for(int i=0;i<100000;i++)
a[i]=i;
for(int i=0;i<100000;i++)
it.push_back(a[i]);
return 0;
在 for(int i=0;i<100000;i++)
it.push_back(a[i]);
之后我如何做 才能让程序占用内存和在这段循环之前的一样多呢?
zbxceeymwq58314184782011-12-23 下午 10:01:44楼主的程序可以编译运行。 确实,楼主的程序隐含存在一个问题--内存泄露。具体原因分析如下: 1、类Vector在类定义中存在一个整型指针成员buffer,这个指针成员在类的构造函数中被动态分配内存,但是,在该类的析构函数定义中未将指针内存释放,因此存在内存泄露。 2、如何解决内存泄露的问题呢?一个简单的方法是在类Vector的析构函数中添加指针内存释放指令,比如: ~Vector()cout<<"Descontructing \n";if (buffer != (int *)NULL) delete buffer; 但是,这样一来,程序反而运行失败。可以看到,程序中有这样的指令 Vector b(a); // 在对象b创建时,将对象a赋值给对象b 执行完这条指令以后,对象b拥有与对象a相同的数据成员,包括指针buffer,即b.buffer与a.buffer的指针值完全相同。当程序执行完最后一条指令退出时,对象a和b都自动调用析构函数,于是同一块内存(由a.buffer和b.buffer共同指向的动态内存)就被释放两次,程序运行失败。同时,也注意到,上述分析证明了程序演示的结果,即当执行上述指令之后,b.disp()还能够输出a.set()的结果。 3、如何解决动态内存两次释放的问题呢?应用到拷贝构造函数,比如如下定义: Vector::Vector(Vector &obj) if (obj.buffer != (int *)NULL) size = obj.size; buffer = new int[size]; memcpy(buffer, obj.buffer, sizeof(int)*size); else buffer = (int *)NULL; 这样的话,当执行指令 Vector b(a); 时,调用该类的拷贝构造函数来进行赋值。可以看到,此时b.buffer与a.buffer指向了不同的内存块,然而这两个内存块中包含相同的内容,真正做到了安全赋值的作用。 参考技术A it.clear();
把里面的元素删掉,内存就还回去了
如果你是想把数组的内存还回去,你开始的时候就
double* a = new double[100000];
然后delete a[]; 参考技术B 光clear是不释放内存的,将你这段代码修改了一下,你看看,应该能明白了,不明白运行一下就知道了。
#include <vector>
#include <iostream>
using namespace std;
main()
vector<double>it;
double a[100000];
for(int i=0;i<100000;i++)
a[i]=i;
cout << "未放元素时容器大小为: " << it.size() << "容器容量为: " << it.capacity() << endl; //未放元素
for(int i=0;i<100000;i++)
it.push_back(a[i]);
cout << "放元素后容器大小为: " << it.size() << "容器容量为: " << it.capacity() << endl; //放元素
it.clear();
cout << "clear后容器大小为: " << it.size() << "容器容量为: " << it.capacity() << endl; //clear
vector<double>().swap(it);
cout << "swap后容器大小为: " << it.size() << "容器容量为: " << it.capacity() << endl; //swap
return 0;
运行结果:
未放元素时容器大小为: 0容器容量为: 0
放元素后容器大小为: 100000容器容量为: 131072
clear后容器大小为: 0容器容量为: 131072
swap后容器大小为: 0容器容量为: 0本回答被提问者采纳
C++ STL std::vector内存释放
(1)vector的内存释放
由于vector的内存占用空间只增不减,比如你首先分配了10,000个字节,然后erase掉后面9,999个,留下一个有效元素,但是内存占用仍为10,000个。所有内存空间是在vector析构时候才能被系统回收。empty()用来检测容器是否为空的,clear()可以清空所有元素。但是即使clear(),vector所占用的内存空间依然如故,无法保证内存的回收。
如果需要空间动态缩小,可以考虑使用deque。如果vector,可以用swap()来帮助你释放内存。具体方法如下:
vector().swap(pointVec); //或者pointVec.swap(vector())
标准模板:
template <class T>
void ClearVector(vector<T>& vt)
vector<T> vtTemp;
veTemp.swap(vt);
swap()是交换函数,使vector离开其自身的作用域,从而强制释放vector所占的内存空间,总而言之,释放vector内存最简单的方法是vector().swap(pointVec)。但是如果pointVec是一个类的成员,不能把vector().swap(pointVec)写进类的析构函数中,否则会导致double free or corruption (fasttop)的错误,原因可能是重复释放内存!(前面的pointVec.swap(vector ())用G++编译没有通过)
(2)其他情况释放内存
如果vector中存放的是指针,那么当vector销毁时,这些指针指向的对象不会被销毁,那么内存就不会被释放。如下面这种情况,vector中的元素是由new操作动态申请出来的对象指针:
#include <vector>
using namespace std;
vector<void *> v;
每次new之后调用v.push_back()该指针,在程序退出或者根据需要,用以下代码进行内存的释放:
for (vector<void *>::iterator it = v.begin(); it != v.end(); it ++)
if (NULL != *it)
delete *it;
*it = NULL;
v.clear();
以上是关于vector内存释放 c++的主要内容,如果未能解决你的问题,请参考以下文章