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_ptr
的 expired
方法:
bool is_shared() const {
return !weak_from_this().expired();
}
我正在尝试创建一个 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_ptr
的 expired
方法:
bool is_shared() const {
return !weak_from_this().expired();
}