智能指针不能自动用作原始指针

Smart pointers cannot be used as raw pointers automatically?

本文关键字:指针 原始 不能 智能      更新时间:2023-10-16

我正在尝试将代码转换为使用智能指针而不是原始指针。 但是想知道 - 智能指针真的不可能用作原始指针吗?

在此示例中:

#include <iostream>
#include <string>
#include <memory>
void printer(int* x)
{
    std::cout << "x = " << x << std::endl;
}
int main()
{   
    auto x = std::make_unique<int>(5);
    printer(x);
    return 0;
}

我收到一个错误:

In function 'int main()': 14:14: error: cannot convert
'std::unique_ptr<int, std::default_delete<int> >' to 'int*' for argument '1'
to 'void printer(int*)' 

应该如何编码? 谢谢!

不能有隐式转换,因为隐式转换没有上下文来执行正确的操作。 printer采用非拥有指针,但其他需要所有权的函数呢?例如

void kill(int *p) { delete p; }

在呼叫kill(p);时默默地进行转换将是错误的事情!这将导致双重删除。指针无法知道它应该停止拥有对象,必须通过调用release来告诉它。其他任何事情都会出错。

由于智能指针都是关于强制实施显式所有权语义的,因此转换为原始指针也需要显式,并且具有传达所有权如何受到影响的名称。

std::make_unique<>()返回一个std::unique_ptr,这使得变量x类型为std::unique_ptr<int>。这些智能指针不仅仅是原始指针,您不能像原始指针一样使用它们。您应该改为在x上使用 get() 方法来获取它指向的int*