

新闻资讯
技术学院std::shared_from_this的作用是让已由std::shared_ptr管理的对象安全生成指向自身的另一个std::shared_ptr;必须公有继承std::enable_shared_from_this,且仅在对象已被shared_ptr拥有后(不可在构造函数中)调用,否则抛std::bad_weak_ptr。
std::shared_from_this 的作用是:让一个已由 std::shared_ptr 管理的对象,能安全地生成指向自身的另一个 std::shared_ptr,避免重复管理或悬空指针。
如果对象已经由某个 shared_ptr 管理(比如被外部创建并传入),你再用 new 或 make_shared 包装 this,会导致两个独立的控制块,引用计数互不感知——析构两次、内存崩溃、UB(未定义行为)。
正确做法是:对象必须继承自 std::enable_shared_from_this,然后调用 shared_from_this()。
std::enable_shared_from_this
shared_ptr 拥有时调用(即:该对象必须是通过 make_shared 或 shared_ptr 构造出来的)std::bad_weak_ptr
比如一个网络连接类需要把自身传给异步读取回调:
class Connection : public std::enable_shared_from_this{ public: void start_read() { auto self = shared_from_this(); // 安全获取自身 shared_ptr socket_.async_read_some(buffer_, [self](auto ec, size_t n) { self->on_read(ec, n); // 即使 Connection 已被释放,self 也能保活 }); } private: tcp::socket socket_; void on_read(std::error_code, size_t) { /* ... */ } };
这样即使外层的 shared_ptr 提前释放,回调里的 self 仍能保证对象存活到回调执行完。
enable_shared_from_this → 编译失败(shared_from_this 未定义)s
hared_ptr 创建(如栈对象或裸指针 new)→ 运行时抛 std::bad_weak_ptr
基本上就这些。shared_from_this 不复杂,但容易忽略前提条件,用对了才能真正安全。