示例解析 C++ 的 new / delete 和 new [] / delete [] 之用法
实例代码:
#include <stdio.h>
#include <windows.h>
// #include <iostream>
#define _CRTDBG_MAP_ALLOC
#include <crtdbg.h>
#ifdef _DEBUG
#define new new(_NORMAL_BLOCK,__FILE__,__LINE__) // 这一行使当检测到new分配的内存泄漏时输出文件名和行号。
#endif
class CTest
{
public:
CTest()
{
printf("构造 CTest, s_n = %d\n", ++s_n);
p = new int[1024*1024*10];
}
~CTest()
{
printf("析构 CTest, s_m = %d\n", ++s_m);
delete [] p;
/* 下面这样做也可以,因为int类型对象没有析构函数需要执行,也完全释放了p所指的内存,不会有内存泄露。*/
//delete p;
}
public:
static int s_n;
static int s_m;
int* p;
};
#define NUM 3
int CTest::s_n = 0;
int CTest::s_m = 0;
int main(int argc, char* argv[])
{
int i;
CTest * p[NUM] = {0};
for(i=0; i<NUM; i++)
{
p[i] = new CTest[3];
_ASSERT(p[i]);
printf("new, p[i] = %d\n", p[i]);
::Sleep(1000);
}
for(i=0; i<NUM; i++)
{
delete [] p[i]; // 正确的做法。
/* 下面是错误的做法!如果这样做,不能调用每个对象的析构函数,会有内存泄露。
* 而且在调试程序时,执行到这被卡住, 但如果把CTest类的析构函数去掉,就不会卡住;
* 如果不在VS环境执行Release版程序,虽然没卡住,但只执行3次析构函数,而不是9次。*/
//delete p[i];
}
system("pause");
_CrtDumpMemoryLeaks();
return 0;
}