本文摘编自https://www.cnblogs.com/charley_yang/archive/2010/12/08/1899982.html
C++告诉我们在回收用 new
分配的单个对象的内存空间的时候用 delete
,回收用 new[]
分配的一组对象的内存空间的时候用 delete[]
。简单来说就是使用delete
释放单个对象,使用delete[]
释放数组对象。
关于 new[]
和 delete[]
,其中又分为两种情况:
下面的代码分别用new, new[]
分配自定义类型的空间、用delete, delete[]
回收自定义类型的空间
#include <iostream>
using namespace std;
class T {
public:
T() { cout << "constructor" << endl; }
~T() { cout << "destructor" << endl; }
};
int main()
{
const int NUM = 3;
T* p1 = new T[NUM];
cout << hex << p1 << endl;
// delete[] p1;
delete p1;
T* p2 = new T[NUM];
cout << p2 << endl;
delete[] p2;
}
在clang++中,这个程序会发生段错误,原因就是使用了delete
来释放p1
对象的空间
constructor
constructor
constructor
0x5fbeb8
destructor
munmap_chunk(): invalid pointer
已放弃 (核心已转储)
如果该段程序可以运行,delete p1
在回收空间的过程中,只有 p1[0]
这个对象调用了析构函数,而其它对象如 p1[1]
、p1[2]
等都没有调用自身的析构函数,这就是问题的症结所在。如果用 delete[]
,则在回收空间之前所有对象都会首先调用自己的析构函数。
基本类型的对象没有析构函数,所以回收基本类型组成的数组空间用 delete
和 delete[]
都是应该可以的;但是对于类对象数组,只能用 delete[]
。对于 new
的单个对象,只能用 delete
不能用 delete[]
回收空间。
简单来说就是:new
配合 delete
使用,而new[]
配合 delete[]
使用。