您的位置首页生活百科

内存泄露的解决办法

内存泄露的解决办法

的有关信息介绍如下:

内存泄露的解决办法

什么是内存泄漏(memoryleak)?

指由于疏忽或错误造成程序未能释放已经不再使用的内存的情况。内存泄漏并非指内存在物理上的消失,而是应用程序分配某段内存后,由于设计错误,失去了对该段内存的控制,因而造成了内存的浪费。

case 1.new/delete成对使用

case 2.正确的清理嵌套的对象指针。

解决办法:

a、在外部函数分配的堆内存,不要在调用函数里面释放,而应该在外部函数释放。

b、尽量在构造函数中分配内存。

c、在基类/继承类中分管各自的内存。

case 3 释放对象数组时,要使用delete []

a、对单个对象、基本类型的变量,用delete;

b、对基本类型数组,采用delete,delete[]均可;

c、对自定义的对象的所组成的对象数组,一定要采用delete [].

case 4 指向对象的指针构成的数组,必须用户自己调用delete。

for example:

Point **pPtrAry = new Point*;// 循环为每个指针分配一个Point对象;int i = 0;for (; i < 10; ++i){pPtrAry[i] = new Point(i, i, "Green");}

// 下面语句并没有释放10个Point对象,释放的只是他们的指针所组成的数组// 占用的10*sizeof(Point*) 空间,造成了内存泄露// (180 = 10*sizeof(Point) + 10* 6; (6= sizeof("Green")))//delete []pPtrAry;

// 正确的方法:for (i = 0; i < 10; ++i){delete pPtrAry[i];}delete[]pPtrAry; // 或者delete pPtrAry;

case 5 对于有指针对象的类,必须有显示的拷贝构造函数。

case 6 必要的重载赋值运算符。

case 7 基类的析构函数定义为虚函数。

这里主要存在基类指针指向派生类的情况。如果析构函数定义为虚函数,则释放基类指针时,如果该指针指向一个派生类,则会先调用派生类的析构函数,再调用基类的析构函数(不管是不是虚函数,派生类的对象析构的时候,都会先调用派生类的析构函数,再调用基类的析构函数)。

最后以下是怎样避免内存泄露:

良好的编码习惯,尽量在涉及内存的程序段,检测出内存泄露。当程式稳定之后,在来检测内存泄露时,无疑增加了排除的困难和复杂度。使用了内存分配的函数,要记得要使用其想用的函数释放掉,一旦使用完毕。