不可复制对象的新放置

时间:2018-09-08 20:50:41

标签: c++11 unique-ptr placement-new noncopyable

我正在尝试模拟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)行是编译错误,因为不能复制唯一指针。

代替复制,我们必须移动唯一的指针。不幸的是,在这种情况下,由于它们位于初始化列表中,因此无法移动。

是否有解决此问题的方法?

1 个答案:

答案 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);
}