参考:https://blog.csdn.net/cbnotes/article/details/38900799
delete和delete []的区别
通常理解为:
- delete 释放new分配的单个对象指针指向的内存
- delete[] 释放new分配的对象数组指针指向的内存
一般对于使用 delete 释放单个对象的内存空间是没有疑问的,而对于使用delete[] 释放数组空间需要分两种情况:
- 对于简单数据类型数组
- 对于自定义数据类型数组
对于简单数据类型数组
使用 delete
int* p = new int[10];
delete a;
与使用delete[]
int* p = new int[10];
delete[] a;
的效果是相同的
这是因为:分配简单类型内存时,内存大小已经确定,系统可以记忆并且进行管理,在析构时,系统并不会调用析构函数,它直接通过指针可以获取实际分配的内存空间。
对于自定义数据类型数组
定义一个类A,其中包含 char *m_cBuffer 需要调用析构函数释放空间
class A
{
private:
char *m_cBuffer;
int m_nLen;
public:
A(){ m_cBuffer = new char[m_nLen]; }
~A() { delete [] m_cBuffer; }
};
A *a = new A[10];
delete a;
仅释放了a指针指向的全部内存空间 但是只调用了a[0]对象的析构函数 剩下的从a[1]到a[9]这9个用户自行分配的m_cBuffer对应内存空间将不能释放 从而造成内存泄漏.
A *a = new A[10];
delete[] a;
调用使用类对象的析构函数释放用户自己分配内存空间并且 ,释放了a指针指向的全部内存空间
总结:
分两种情况:
- 对于基本数据类型所构成的数组,delete和delete[]作用是一样的
- 对于自定义数据类型所构成的数组
– delete p 表示释放p所指向的内存地址空间
– delete [] p 表示释放p所指向的内存地址空间,并逐个调用数组中每个对象的析构函数