先看以下代码
st是自定义类型,默认调用构造和析构
pst的类型是指针,是内置类型,必须得手动调用构造和析构
前者和后者区别是什么?
new的流程是先malloc一块堆上空间,然后调用构造函数初始化,即调用底层operator new,operator new把malloc封装了,跟c不同的是c++是面向对象语言,c的malloc错了会返回0,c++会报异常
delete的流程是先调用析构函数,注意,如果是局部变量则会自动销毁,如果是栈上的需要调用析构,然后再free掉
按上面代码的例子来说,
st是局部对象,在栈上开辟了一块空间,_a指向堆上一块空间,st是自定义类型,会自动调用析构函数把这块空间给带走
pst是个指针,new的时候会先开12个字节的空间,然后调用构造函数,构造函数里的_a又new了一块空间,delete的时候会先调用析构函数,把_a指向的空间析构掉,然后再调用free,把pst指向的空间释放,如果delete pst改成free(pst),没有调用析构函数,也就是直接把pst指向的空间释放,_a指向的空间没有释放,会导致内存泄漏,一般编译器不会报错,有些情况也是会报错的,例如:
不同编译器机制不同,vs编译器会在new的空间前开四个字节的空姐存储个数,所以free和delete报错是因为指针位置不对,delete[]会用p9位置的地址往前减四个字节,存储个数是为了知道调用多少次析构函数,如果把析构函数屏蔽了,就不会多开四个字节,free和delete就不会报错
所以建议要匹配使用