我一直看到智能指针reset
函数与原始指针一起使用。当我尝试将另一个智能指针传递给它时,它会失败。我看了看这里:http://en.cppreference.com/w/cpp/memory/shared_ptr/reset
但它并没有多说这个。只是想确认是否是这种情况?我的代码在这里:https://wandbox.org/permlink/xKNtJhjGeOSZS7KN
同样为了您的方便:
#include<iostream>
using std::cout; using std::endl;
#include<memory>
using std::shared_ptr;
class Widget
{
public:
~Widget()
{
cout << "Hi from destructor" << endl;
}
};
auto wdel = [](Widget* pw)
{
cout << "Hi from custom deleter" << endl;
delete pw;
};
int main()
{
{
shared_ptr<Widget> pw(nullptr,wdel);
pw.reset(new Widget);
cout << "Done reset" << endl;
shared_ptr<Widget> pw2(nullptr,wdel);
// pw = pw2; // this works
pw2.reset(pw); // this does not work
}
return 0;
}
提前谢谢。
答案 0 :(得分:4)
pw2 = pw
是正确的,只有副本(使用shared_ptr::operator&
或shared_ptr::shared_ptr
)才能正确。
考虑是否有第三个shared_ptr
。这样做有权将所有权保持为pw
,因此不允许pw
将所有权转让给其他地方。
您可以pw2 = pw; pw.reset(nullptr);
将pw
的所有权发布到pw2
,因为这不会影响共享Widget的其他指针。
答案 1 :(得分:3)
从智能指针到原始指针的隐式转换非常危险。所以它不会发生。
如果智能指针认为它正在管理另一个智能指针正在管理的指针,则两者都认为他们有权清理它。当第二个人进行清理时,通常会发生不好的事情。
原始指针不包含所有权信息。
另一方面,当您将一个共享指针分配给另一个时,也会共享有关指针生命周期的信息。所以两个人合作管理指针的生命周期,最后一个离开skope进行清理。