检查派生自enable_shared_from_this的对象是否由shared_ptr管理?

Check whether an object derived from enable_shared_from_this is managed by shared_ptr?

本文关键字:shared 是否 ptr 管理 对象 this 派生 enable from 检查      更新时间:2023-10-16

假设我有一个从std::enable_shared_from_this派生的类

struct foo
: std::enable_shared_from_this<foo>
{
std::shared_ptr<foo> get_shared()
{
return shared_from_this();
}
bool is_shared() const
{
/* implementation ??? */
}
};
foo  A;
auto S= A.get_shared();   // UB (pre c++17) or exception (c++17)

在 c++17 之前,似乎没有办法检测对象foo是否实际由shared_ptr管理。正确?

但即使对于 c++17,我也不确定如何最好地实现这样的检测。一个明显的方法是

bool foo::is_shared() const
{
try {
shared_from_this();
} catch(...) { 
return false;
}
return true;
}

但是try-catch可以避免吗?我可以使用weak_from_this()吗?如何?

您可以在C++17 中实现is_shared利用weak_from_this(),如下所示:

bool is_shared() const
{
return !weak_from_this().expired();
}

这是无异常的,只会返回true对象实际上由shared_ptr管理。

在 C++17 之前,没有办法进行检查,因为当对象不属于shared_ptr时调用shared_from_this()是未定义的行为。 直到 C++17 引入了weak_from_this(),我们才可以访问std::enable_shared_from_this的私有weak_ptr成员(通过副本),我们才能以定义的方式检查状态。