unique_ptr具有右值删除器的构造函数返回 null



这是我用来理解std::unique_ptr行为的代码片段:

std::default_delete<int> d;
std::unique_ptr<int> u1;
std::unique_ptr<int> u2 (nullptr);
std::unique_ptr<int> u3 (new int);
std::unique_ptr<int> u4 (new int, d);
std::unique_ptr<int> u5 (new int, std::default_delete<int>());
std::unique_ptr<int> u6 (std::move(u5));
std::unique_ptr<int> u7 (std::move(u6));
std::unique_ptr<int> u8 (std::auto_ptr<int>(new int));
std::cout << "u1: " << (u1?"not null":"null") << 'n';
std::cout << "u2: " << (u2?"not null":"null") << 'n';
std::cout << "u3: " << (u3?"not null":"null") << 'n';
std::cout << "u4: " << (u4?"not null":"null") << 'n';
std::cout << "u5: " << (u5?"not null":"null") << 'n';
std::cout << "u6: " << (u6?"not null":"null") << 'n';
std::cout << "u7: " << (u7?"not null":"null") << 'n';
std::cout << "u8: " << (u8?"not null":"null") << 'n';

有人可以解释为什么null是为u5u6而印刷的,而不是为u7印刷的吗?提前感谢!

正如 Phil1970 在他的评论中指出的那样,std::unique_pointer实例在分配给另一个实例后变得(等效于(nullptr(使用 std::move,如您的代码示例中所示(。实际上,这就是std::unique_ptr的目的。它是独一无二的。

现在考虑这段代码:

#include <memory>
#include <iostream>
int main()
{
    std::default_delete<int> d;
    std::unique_ptr<int> u1;
    std::cout << "u1: " << (u1 ? "not null" : "null") << 'n';
    std::unique_ptr<int> u2(nullptr);
    std::cout << "u2: " << (u2 ? "not null" : "null") << 'n';
    std::unique_ptr<int> u3(new int);
    std::cout << "u3: " << (u3 ? "not null" : "null") << 'n';
    std::unique_ptr<int> u4(new int, d);
    std::cout << "u4: " << (u4 ? "not null" : "null") << 'n';
    std::unique_ptr<int> u5(new int, std::default_delete<int>());
    std::cout << "u5: " << (u5 ? "not null" : "null") << 'n';
    std::unique_ptr<int> u6(std::move(u5));
    std::cout << "u6: " << (u6 ? "not null" : "null") << 'n';
    std::unique_ptr<int> u7(std::move(u6));
    std::cout << "u7: " << (u7 ? "not null" : "null") << 'n';
}

执行时,您会看到u5u6在实例化后立即为"不为空"。

最新更新