检查派生自enable_shared_from_this的对象是否由shared_ptr管理?
Check whether an object derived from enable_shared_from_this is managed by shared_ptr?
假设我有一个从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
成员(通过副本),我们才能以定义的方式检查状态。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 在shared_from_this()中的错误类型(在继承类中)(是否有dyn.type-ware shared Poi