placement new 运算符的问题
Problems with the placement new operator
我了解 placement new 运算符允许在 particular/specific 内存位置构造对象。所以我尝试了这个;
#include <iostream>
#include <new>
using namespace std;
struct Any {
int x;
string y;
};
int main() {
string mem1[1];
int mem2[5];
Any *p1 = new (mem1) Any;
Any *p2 = new (mem2) Any;
p1->y = "Hello";
//p2->x = 20;
cout << p1->y << endl;
//cout << p2->x;
return 0;
}
我意识到,我可以将一个字符串设置到我预留的位置以正好容纳 1 个字符串,但我不能像这样对整数做同样的事情;
int mem2[1];
Any *p2 = new (mem2) Any;
p2->x = 20;
我收到缓冲区溢出错误,即使它设法向我显示我放置在 20
;
位置的值
为什么?
此外,根据上面显示的完整代码,我预留了 2 个不同的内存位置来保存 2 个对象,这使得 p1->y
打印没有任何问题。但是当我减少这个位置时
int mem2[5];
到 5
以下的任何数字,我认为这与我放置字符串的位置无关并尝试打印字符串,我得到一个分段错误。为什么 >= 5
?是否与可用内存有关?
有没有办法检查使用 placement new 运算符将对象放置在特定内存位置是否成功?
您的代码中有几组未定义的行为。
首先,不能保证声明 string mem[1];
留出足够的内存来包含类型 Any
...
其次,即使第一个有足够的内存来保存这样的对象,数组 string mem[1];
的析构函数仍将 运行 在 main 的末尾,但是你已经用别的东西,因此你的程序最多应该是崩溃。
您可能想要使用 POD 类型,例如 char mem1[sizeof(Any)]
来存储对象,这样您就可以确定 mem1
有足够的能力存储 Any
,并且您'在 main()
结束时调用 mem1
的析构函数不会有任何问题
同样,您可能想为这种事情探索一个标准设施,std::aligned_storage
我了解 placement new 运算符允许在 particular/specific 内存位置构造对象。所以我尝试了这个;
#include <iostream>
#include <new>
using namespace std;
struct Any {
int x;
string y;
};
int main() {
string mem1[1];
int mem2[5];
Any *p1 = new (mem1) Any;
Any *p2 = new (mem2) Any;
p1->y = "Hello";
//p2->x = 20;
cout << p1->y << endl;
//cout << p2->x;
return 0;
}
我意识到,我可以将一个字符串设置到我预留的位置以正好容纳 1 个字符串,但我不能像这样对整数做同样的事情;
int mem2[1];
Any *p2 = new (mem2) Any;
p2->x = 20;
我收到缓冲区溢出错误,即使它设法向我显示我放置在 20
;
为什么?
此外,根据上面显示的完整代码,我预留了 2 个不同的内存位置来保存 2 个对象,这使得 p1->y
打印没有任何问题。但是当我减少这个位置时
int mem2[5];
到 5
以下的任何数字,我认为这与我放置字符串的位置无关并尝试打印字符串,我得到一个分段错误。为什么 >= 5
?是否与可用内存有关?
有没有办法检查使用 placement new 运算符将对象放置在特定内存位置是否成功?
您的代码中有几组未定义的行为。
首先,不能保证声明 string mem[1];
留出足够的内存来包含类型 Any
...
其次,即使第一个有足够的内存来保存这样的对象,数组 string mem[1];
的析构函数仍将 运行 在 main 的末尾,但是你已经用别的东西,因此你的程序最多应该是崩溃。
您可能想要使用 POD 类型,例如 char mem1[sizeof(Any)]
来存储对象,这样您就可以确定 mem1
有足够的能力存储 Any
,并且您'在 main()
mem1
的析构函数不会有任何问题
同样,您可能想为这种事情探索一个标准设施,std::aligned_storage