【问题标题】:How copying a unique_ptr of one type to another works将一种类型的 unique_ptr 复制到另一种类型的工作原理
【发布时间】:2016-06-26 00:33:59
【问题描述】:

参考以下代码

#include <iostream>
#include <memory>
using std::cout;
using std::endl;
using std::make_unique;

struct Base {};
struct Derived : public Base {};

int main() {

    auto base_uptr = std::unique_ptr<Base>{make_unique<Derived>()};
    return 0;
}

unique_ptr 调用了哪个构造函数?我看了一下cppreference.com,我发现的构造函数(pre c++17)是(为了完成)

constexpr unique_ptr();
constexpr unique_ptr( nullptr_t );
explicit unique_ptr( pointer p );
unique_ptr( pointer p, /* see below */ d1 );
unique_ptr( pointer p, /* see below */ d2 );
unique_ptr( unique_ptr&& u );

template< class U, class E >
unique_ptr( unique_ptr<U, E>&& u );

它们似乎都不接受其他类型的指针。我错过了什么?调用了哪个构造函数?

谢谢!

【问题讨论】:

    标签: c++ c++11 unique-ptr


    【解决方案1】:

    第 6 号,模板构造函数。

    template< class U, class E >
    unique_ptr( unique_ptr<U, E>&& u );
    

    除其他几个条件外,这还要求 "unique_ptr&lt;U, E&gt;::pointer 可以隐式转换为 pointer"。换句话说,U* 需要隐式转换为您的unique_ptr 存储的指针类型。在您的情况下,它是,因为 Derived* 可以隐式转换为 Base*

    【讨论】:

      猜你喜欢
      • 2021-04-11
      • 2011-05-30
      • 2019-12-04
      • 1970-01-01
      • 1970-01-01
      • 2015-12-03
      • 1970-01-01
      • 2021-09-07
      • 2012-03-28
      相关资源
      最近更新 更多