其他分享
首页 > 其他分享> > c – 查看std :: unique_ptr及其nullptr_t构造函数

c – 查看std :: unique_ptr及其nullptr_t构造函数

作者:互联网

我试图理解为什么unique_ptr有一个nullptr_t构造函数

constexpr unique_ptr::unique_ptr( nullptr_t );

我假设这是因为正常的一个参数构造函数是显式的,因此会拒绝nullptr值:

explicit unique_ptr::unique_ptr( pointer p );

但是当我构建一个例子时,编译器很好:

namespace ThorsAnvil
{
    template<typename T>
    class SmartPointer
    {
        public:
            SmartPointer()      {}
            explicit SmartPointer(T*){}
    };
}


template<typename T>
using SP    = ThorsAnvil::SmartPointer<T>;
int main()
{

    SP<int>     data1;
    SP<int>     data2(new int);  // fine
    SP<int>     data3(nullptr);  // fine
}

这是输出:

> g++ --version
Configured with: --prefix=/Applications/Xcode.app/Contents/Developer/usr --with-gxx-include-dir=/usr/include/c++/4.2.1
Apple LLVM version 6.0 (clang-600.0.56) (based on LLVM 3.5svn)
Target: x86_64-apple-darwin14.0.0
Thread model: posix
> g++ -Wall -Wextra -std=c++11 SP1.cpp

为什么std :: unique_ptr需要额外的构造函数来获取nullptr_t参数?

解决方法:

SP<int>     data3(nullptr);  // fine

您正在使用直接初始化,这会导致考虑显式构造函数.尝试以下操作,您的代码将无法编译

SP<int>     data4 = nullptr;

现在添加以下构造函数,上面的行将编译

SmartPointer(std::nullptr_t){}

因此,nullptr_t构造函数使unique_ptr在您想要将其初始化为nullptr的情况下表现得像原始指针,但在其他可能实际为其指定原始指针的情况下避免任何意外的所有权转移.

标签:c,c11,unique-ptr,nullptr
来源: https://codeday.me/bug/20190824/1711884.html