尚未归shared_ptr所有的实例的 shared_from_this() 总是返回 null?

shared_from_this() of an instance that is not yet owned by shared_ptr always returns null?

本文关键字:shared 返回 null this 实例 ptr from      更新时间:2023-10-16

我正在尝试创建一个成员函数,该函数返回它是否已存储到shared_ptr

class X : public std::enable_shared_from_this {
...
bool is_shared() const {
return shared_from_this();
}
};
...
(new X())->is_shared(); // -> false?

这合法吗?在这种情况下,shared_from_this(( 是否保证返回 null 并且不引发任何异常?

shared_from_this

可用于从已由shared_ptr管理的对象获取shared_ptr

在非共享对象上调用shared_from_this是 C++11 中未定义的行为。

但是,在 C++17 中,shared_from_this将抛出bad_weak_ptr,您可以捕获此异常:

#include <memory>
#include <iostream>
class X : public std::enable_shared_from_this<X> {
public:
bool is_shared() const {
try {
shared_from_this();
return true;
} catch (std::bad_weak_ptr&) {
return false;
}
}
};
int main() {
X x;
std::cout << std::boolalpha << x.is_shared() << std::endl;
auto y = std::make_shared<X>();
std::cout << y->is_shared() << std::endl;
}

输出:

false
true

此外,您可以使用weak_from_this来访问weak_ptrexpired方法:

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