内存泄露的解决办法
什么是内存泄漏(memory leak)?
指由于疏忽或错误造成程序未能释放已经不再使用的内存的情况。内存泄漏并非指内存在物理上的消失,而是应用程序分配某段内存后,由于设计错误,失去了对该段内存的控制,因而造成了内存的浪费。
操作方法
- 01
case 1.new/delete成对使用 case 2.正确的清理嵌套的对象指针。 解决办法: a、在外部函数分配的堆内存,不要在调用函数里面释放,而应该在外部函数释放。 b、尽量在构造函数中分配内存。 c、在基类/继承类中分管各自的内存。
- 02
case 3 释放对象数组时,要使用delete [] a、对单个对象、基本类型的变量,用delete; b、对基本类型数组,采用delete,delete[]均可; c、对自定义的对象的所组成的对象数组,一定要采用delete [].
- 03
case 4 指向对象的指针构成的数组,必须用户自己调用delete。 for example: Point **pPtrAry = new Point*[10]; // 循环为每个指针分配一个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;
- 04
case 5 对于有指针对象的类,必须有显示的拷贝构造函数。
- 05
case 6 必要的重载赋值运算符。
- 06
case 7 基类的析构函数定义为虚函数。
- 07
这里主要存在基类指针指向派生类的情况。如果析构函数定义为虚函数,则释放基类指针时,如果该指针指向一个派生类,则会先调用派生类的析构函数,再调用基类的析构函数(不管是不是虚函数,派生类的对象析构的时候,都会先调用派生类的析构函数,再调用基类的析构函数)。
- 08
最后以下是怎样避免内存泄露: 良好的编码习惯,尽量在涉及内存的程序段,检测出内存泄露。当程式稳定之后,在来检测内存泄露时,无疑增加了排除的困难和复杂度。使用了内存分配的函数,要记得要使用其想用的函数释放掉,一旦使用完毕。