❥关于C++之定位new运算符•显示调用析构函数

本文探讨了程序员如何使用定位new运算符分配内存,并强调了确保析构函数正确调用的重要性。讲解了delete与new[]的配合问题,以及如何手动销毁定位new的对象。关键点包括内存区域管理、析构函数的调用规则和释放缓冲区的正确方式。
摘要由CSDN通过智能技术生成

程序员必须负责管用定位new运算符用从中使用的缓冲区内存单元。要使用不同的内存单元,程序员需要提供两个位于缓冲区的不同地址,并确保这两个内存单元不重叠。例如,可以这样做:

char* buffer = new char[512];
JustTesting* pc1 = new (buffer) JustTesting;// place object in buffer
JustTesting* pc2 = new (buffer + sizeof (JustTesting)) JustTesting("Better Idea", 6);

其中指针pc2相对于pc1的偏移量为JustTesting对象的大小。

如果使用定位new运算符来为对象分配内存,必须确保其析构函数被调用。

但如何确保析构函数被调用呢?

JustTesting* pc0 = new JustTesting("Heap1", 20);
delete pc0;// OK
delete pc2;// NO!
delete pc1;// NO!

以上代码原因在于:delete可与常规new运算符配合使用,但不能与定位new运算符配合使用。

指针pc1指向的地址与buffer相同,但buffer是使用new []初始化的,因此必须使用delete []而不是delete来释放。即使buffer是使用new而不是new []初始化的,delete pc1也将释放buffer,而不是pc1。这是因为new/delete系统知道已分配的512字节块buffer,但对定位new运算符对该内存块做了何种处理一无所知。

该程序确实释放了buffer:delete [] buffer;

delete [] buffer;释放使用常规new运算符分配的整个内存块,但它没有为定位new运算符在该内存块中创建的对象调用析构函数。

这种问题的解决方案是:显式地为使用定位new运算符创建的对象调用析构函数。

pc2->~JustTesting(); // 销毁pc2指向的对象
pc1->~JustTesting(); // 销毁pc1指向的对象

需要注意的一点是正确的删除顺序。对于使用定位new运算符创建的对象,应以与创建顺序相反的顺序进行删除。

原因在于,晚创建的对象可能依赖于早创建的对象。另外,仅当所有对象都被销毁后,才能释放用于存储这些对象的缓冲区。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

itzyjr

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值