关于placement new操作
来源:互联网 发布:ugm和mac队关系 编辑:程序博客网 时间:2024/06/05 01:50
如果我是用new分配对象的,可以显式调用析构函数吗?
可能不行。
除非你使用定位放置new,否则应该 delete 对象而不是显式调用析构函数。例如,假设通过一个典型的 new 表达式分配一个对象:
那么,当你delete它时,析构函数 Fred::~Fred() 会被调用:
由于显式调用析构函数不会释放 Fred 对象本身分配的内存,因此不要这样做。记住:delete p 做了两件事情:调用析构函数,回收内存。
什么是“定位放置new(placement new)”,为什么要用它 ?
定位放置new(placement new)有很多作用。最简单的用处就是将对象放置在内存中的特殊位置。这是依靠new表达式部分的指针参数的位置来完成的:
#include "Fred.h" // class Fred 的声明
void someCode()
{
char memory[sizeof(Fred)]; // Line #1
void* place = memory; // Line #2
Fred* f = new(place) Fred(); // Line #3 (详见以下的“危险”)
// The pointers f and place will be equal
// ...
}
Line #1 在内存中创建了一个sizeof(Fred)字节大小的数组,足够放下Fred 对象。Line #2 创建了一个指向这块内存的首字节的place指针(有经验的 C 程序员会注意到这一步是多余的,这儿只是为了使代码更明显)。Line #3 本质上只是调用了构造函数Fred::Fred()。Fred构造函数中的this指针将等于place。因此返回的 f 将等于place。
建议:万不得已时才使用“placement new”语法。只有当你真的在意对象在内存中的特定位置时才使用它。例如,你的硬件有一个内存映象的 I/O计时器设备,并且你想放置一个Clock对象在那个内存位置。
危险:你要独自承担这样的责任,传递给“placement new”操作符的指针所指向的内存区域必须足够大,并且可能需要为所创建的对象进行边界调整。编译器和运行时系统都不会进行任何的尝试来检查你做的是否正确。如果Fred 类需要将边界调整为4字节,而你提供的位置没有进行边界调整的话,你就会亲手制造一个严重的灾难(如果你不明白“边界调整”的意思,那么就不要使用placementnew语法)。
你还有析构放置的对象的责任。这通过显式调用析构函数来完成:
{
char memory[sizeof(Fred)];
void* p = memory;
Fred* f = new(p) Fred();
// ...
f->~Fred(); // 显式调用定位放置的对象的析构函数
}
这是显式调用析构函数的唯一时机。
- 关于placement new操作
- 关于C++中的placement new操作符
- placement new 操作符
- placement new 操作符
- placement new 操作符
- placement new 操作符
- placement new操作符
- 关于placement new
- 关于placement new
- 关于placement new
- placement new 布局new操作
- 关于new operator, operator new, placement new
- C++ 中的 placement new 操作
- C++ placement new操作符
- 关于new delete和placement new,placement delete
- 关于C++的placement new和placement delete
- C++中placement new操作符
- C++中placement new操作符
- Java关于继承中的转型及其内存分配
- 学好英语必不可少:语法与语感
- UE3 贴图支持及设置
- 什么是显卡,显卡的主要部件和主要技术规格有哪些
- const 用法
- 关于placement new操作
- 集合类概述
- LeetCode: Largest Rectangle in Histogram
- .内部类
- 异常
- Windows进程间通信
- Android系统Surface制的SurfaceFlinger服务的启动过程分析
- Jvm
- pdflush.c代码注释