shared_ptr 尚未拥有的实例的 shared_from_this() 始终 returns 为空?

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

我正在尝试创建一个 return 是否已存储到 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() 是否保证 return 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();
}