|
对于C++的内存泄漏,总结一句话:就是new出来的内存没有通过delete合理的释放掉! 一、程序循环new创建出来的对象没有及时的delete掉,导致了内存的泄露;
代码如下:
- #include <iostream>
- #include <new.h>
- using namespace std;
- void out_of_memroy()
- {
- cout << "ERROR:内存已耗尽!" << endl;
- }
- int main()
- {
- set_new_handler(out_of_memroy);//注意参数传递的是函数的地址;
- while(1)
- {
- new int[1000];
- }
- return 0;
- }
复制代码
以上代码会在堆区疯狂的动态分配内存空间,导致系统内存耗尽时自动调用set_new_handler参数列表中的函数,打印出ERROR:内存已耗尽!如下图:
二、delete掉一个void*类型的指针,导致没有调用到对象的析构函数,析构的所有清理工作都没有去执行从而导致内存的泄露;
代码如下:
- class Object {
- private:
- void* data;
- const int size;
- const char id;
- public:
- Object(int sz, char c):size(sz), id(c){
- data = new char[size];
- cout << "Object() " << id << " size = " << size << endl;
- }
- ~Object(){
- cout << "~Object() " << id << endl;
- delete []data;
- }
- };
复制代码
紧接着使我们的main函数:
- int main() {
- Object* a = new Object(10, 'A');//Object*指针指向一个Object对象;
- void* b = new Object(20, 'B');//void*指针指向一个Object对象;
- delete a;//执行delete,编译器自动调用析构函数;
- delete b;//执行delete,编译器不会调用析构函数,导致data占用内存没有得到回收;
- cout << "Press any key to continue... ..." << endl;
- getchar();
- return 0;
- }
复制代码
执行结果如下图:
从执行结果看到,并没有执行b指针(void*)所指对象的析构函数,所以delete一个void*的指针可能会造成内存上的泄露! 三、new创建了一组对象数组,内存回收的时候却只调用了delete而非delete []来处理,导致只有对象数组的第一个对象的析构函数得到执行并回收了内存占用,数组的其他对象所占内存得不到回收,导致内存泄露; 代码如下:
- class Object1
- {
- int a;
- int b;
- };
- int main() {
- Object1* arry1 = new Object1[100];//创建包含100个Object1的对象数组arry1并返回数组首地址;
- Object1* arry2 = new Object1[100];//创建包含100个Object1的对象数组arry2并返回数组首地址;
- delete []arry1;//回收了数组arry1里的所有对象动态创建时占用的内存空间;
- delete arry2;//回收了数组arry2里的第一个对象动态创建时占用的内存空间,导致其他99个对象的内存空间泄露;
- cout << "Press any key to continue... ..." << endl;
- getchar();
- return 0;
- }
复制代码
|