显式构造函数调用
Explicit constructor call
本文关键字:函数调用 更新时间:2023-10-16
我想知道是否有某种技巧可以使用对象指针显式调用构造函数。如果这是一个合法的语法,它看起来是这样的:
Foo *p = malloc( sizeof(Foo) );
p->Foo::Foo();
第页。S.我知道我可以做Foo *p = new Foo();
,但显式使用malloc()有一个严重的原因。
您可以为此使用"placement new"运算符:
Foo *buf = malloc( sizeof(Foo) );
Foo *p = new (buf) Foo();
使用放置新:
Foo* p = new(malloc(sizeof(Foo))) Foo;
(此处忽略任何内存不足检查)
基本上,new(address) Foo()
在address
指向的位置构造Foo
类型的对象,换句话说:它调用构造函数。
您可以使用placement new在某个地址构造新对象。
void *buf = malloc(sizeof(Foo));
Foo *p = new (buf) Foo();
您可以在维基百科上阅读更多关于它的文章
其他人已经指出,您可以使用placement new。如果您希望某个类的某些特定对象位于用malloc
分配的内存中,那么这种方法效果很好。正如已经指出的那样,在执行此操作时,需要显式调用dtor。
如果希望类的所有对象都在用malloc
分配的内存中,则可以重载该类的operator new
(和operator delete
),并让它们调用malloc
来获取原始内存。这减轻了客户端代码单独分配/初始化的额外步骤。
如果希望一个集合(或多个集合)中的所有对象都在使用malloc
分配的内存中,则可以为该集合提供分配器来实现这一点。同样,这减轻了客户端代码处理分配的负担,并使容器看起来、行为和"感觉"像一个正常的容器。
struct MyClass
{
MyClass()
{
std::cout << "ctor" << std::endl;
}
~MyClass()
{
std::cout << "dtor" << std::endl;
}
};
int main(int argc, char *argv[])
{
// Allocate memory and call constructor
MyClass myObj;
// Call constructor again with placement new
new (&myObj) MyClass;
}
相关文章:
- 函数调用中参数的顺序重要吗
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 变量没有改变?通过向量的函数调用
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- 我知道函数调用中存在歧义.有没有办法调用foo()函数
- 模板函数调用
- 获取从C++中同一类中的构造函数调用的方法返回的值
- 析构函数调用
- 成员函数调用和C++对象模型
- 使用共享指针的函数调用,其对象应为 const
- C++:编译时检查匹配的函数调用对?
- 函数调用C++中的参数太少
- 来自 DLL 的函数调用 [表观调用的括号前面的表达式必须具有(指向-)函数类型]
- 返回指向对象的指针的函数调用是否为 prvalue?
- C++ 如何重载 [] 运算符并进行函数调用
- 代码的效率. 转到和函数调用
- 是同一作用域的函数部分中的函数调用
- 如何封装一个函数,以便它只能由同一类中的一个其他函数调用?
- 类型擦除的std::function与虚拟函数调用的开销