C++中delete和delete[]的区别
一直对C++中的delete和delete[]的区别不甚了解,今天遇到了,上网查了一下,得出了结论。做个备份,以免丢失。
C++告诉我们在回收用new分配的单个对象的内存空间的时候用delete,回收用new[]分配的一组对象的内存空间的时候用delete[]。 关于new[]和delete[],其中又分为两种情况:(1)为基本数据类型分配和回收空间;(2)为自定义类型分配和回收空间。
请看下面的程序。
#include<iostream>; usingnamespacestd; classT{ public: T(){cout<<"constructor"<<endl;} ~T(){cout<<"destructor"<<endl;} }; intmain() { constintNUM=3; T*p1=newT[NUM]; cout<<hex<<p1<<endl; //delete[]p1; deletep1; T*p2=newT[NUM]; cout<<p2<<endl; delete[]p2; }
大家可以自己运行这个程序,看一看deletep1和delete[]p1的不同结果,我就不在这里贴运行结果了。
从运行结果中我们可以看出,deletep1在回收空间的过程中,只有p1[0]这个对象调用了析构函数,其它对象如p1[1]、p1[2]等都没有调用自身的析构函数,这就是问题的症结所在。如果用delete[],则在回收空间之前所有对象都会首先调用自己的析构函数。 基本类型的对象没有析构函数,所以回收基本类型组成的数组空间用delete和delete[]都是应该可以的;但是对于类对象数组,只能用delete[]。对于new的单个对象,只能用delete不能用delete[]回收空间。 所以一个简单的使用原则就是:new和delete、new[]和delete[]对应使用。
我的理解,当用delete来释放用newint[]申请的内存空间时,由于其为基本数据类型没有析构函数,所以使用delete与delete[]相同,两者都会释放申请的内存空间,若是自定义的数据类型,有析构函数时,用new[]申请的空间,必须要用delete[]来释放,因为要delete[]时会逐一调用对象数组的析构函数,然后释放空间,如果用delete,则只会调用第一个对象的析构函数,后面对象的析构函数没有被调用,那么其空间是否释放了呢??