我正在尝试模拟vector
的唯一指针,只是为了学习放置新元素如何处理无法复制的对象。
class Person
{
string name;
const int born;
public:
Person (string N, int B) : name(N), born(B) {}
};
int main()
{
using T = unique_ptr <Person>;
int capacity = 4, size = 0;
T* royals = (T*) ::operator new (sizeof(T) * capacity);
for (const T& item: {
make_unique <Person> ("Elizabeth", 1926),
make_unique <Person> ("Philip", 1921) })
{
new (royals + size) T(item);
++size;
}
::operator delete (royals);
}
new (royals + size) T(item)
行是编译错误,因为不能复制唯一指针。
代替复制,我们必须移动唯一的指针。不幸的是,在这种情况下,由于它们位于初始化列表中,因此无法移动。
是否有解决此问题的方法?
答案 0 :(得分:1)
初始化array instead of initializer list中的唯一指针。数组中的对象可以移出,这与初始化列表中的对象不同。
int main()
{
using T = unique_ptr <Person>;
int capacity = 4, size = 0;
T* royals = (T*) ::operator new (sizeof(T) * capacity);
T init[] = {
make_unique <Person> ("Elizabeth", 1926),
make_unique <Person> ("Philip", 1921)
};
for (T& item: init)
{
new (royals + size) T(move(item));
++size;
}
::operator delete (royals);
}