为什么 std::make_unique 调用复制构造函数?

4
我想知道为什么 make_unique 调用了复制构造函数但没有调用默认构造函数。
Node()
{
    std::cout << "default";
}

~Node(){
    std::cout << " Delete";
}

Node(const Node& other ){
    std::cout << "copy";
}

int main(){
    Node<int,int,int,int> test1; //Calling default Cons
    std::unique_ptr<Node<int,int,int,int>> test2  = 
                               std::make_unique<Node<int,int,int,int>>(test1);//Nothing called

    Node<int,int,int,int> *test3 = test2.get();
    Node<int,int,int,int> test4 = Node<int,int,int,int>(*test3);// Calling copy Cons

    std::unique_ptr<Node<int,int,int,int>> test5 = 
                            std::make_unique<Node<int,int,int,int>(test4);//Calling copy Cons
}

例如在上面的代码中: 首先,我们创建一个Node对象-> 调用默认构造函数。 然后将此对象包装到智能指针对象中->没有调用。 但是,如果我们对Node对象进行深层复制->调用复制构造函数 然后将副本包装到智能指针对象中->调用复制构造函数。 这与创建新控制块有关吗?

得到了一个默认值和三个预期的副本 演示 - Jarod42
1个回答

5
std::unique_ptr<Node<int,int,int,int>> test5 = 
   std::make_unique<Node<int,int,int,int>(test4);// You copy from test4

std::make_unique 创建一个新的指针,并不会重用现有的指针。 因此,由于test4已经存在,它必须进行复制。在构造test5之后,test4仍然存在(因此无法移动),而test5持有一个新对象,从test4复制而来。


谢谢,我忽略了在包装test1复制构造函数时也会调用它。 - XYZCODE123

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接