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

时间:2018-05-02 13:15:28

标签: c++ c++11 shared-ptr

我正在尝试创建一个成员函数,返回它是否已存储到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并且不抛出任何异常?

1 个答案:

答案 0 :(得分:5)

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_ptr的{​​{1}}方法:

expired