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]);

之后我如何做 才能让程序占用内存和在这段循环之前的一样多呢?

couvluzkst7224804053mppwvspoit0628606864很不错哦,你可以试下
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++的主要内容,如果未能解决你的问题,请参考以下文章

释放与 C++ 中的结构关联的所有内存

C++中清空Vector内元素的方法以及释放内存

std::vector - 如何释放向量中 char* 元素的内存?

vector的clear会释放动态内存吗

正确释放Vector等STL的内存

使用 std::vector 和内存释放