答案:std::enable_shared_from_this允许类通过shared_from_this安全返回指向自身的shared_ptr,前提是对象已被shared_ptr管理。

在C++中,使用std::shared_ptr管理对象生命周期时,有时需要在类的成员函数内部返回当前对象的std::shared_ptr。直接通过new或this构造std::shared_ptr是危险且错误的做法,会导致多次释放或引用计数不一致。为了解决这个问题,C++提供了std::enable_shared_from_this和shared_from_this()机制。
std::enable_shared_from_this是一个模板基类,继承它后,派生类可以通过调用shared_from_this()安全地获取指向自身的std::shared_ptr。这个机制确保所有指向该对象的shared_ptr共享同一份引用计数。
关键点:只有当对象已经被至少一个std::shared_ptr管理时,才能调用shared_from_this(),否则会抛出std::bad_weak_ptr异常。
以下是一个典型用法示例:
立即学习“C++免费学习笔记(深入)”;
#include <memory>
#include <iostream>
class MyClass : public std::enable_shared_from_this<MyClass> {
public:
MyClass() { std::cout << "MyClass constructed\n"; }
~MyClass() { std::cout << "MyClass destructed\n"; }
// 安全返回当前对象的 shared_ptr
std::shared_ptr<MyClass> get_shared() {
return shared_from_this();
}
void do_something() {
std::cout << "Doing something...\n";
}
};
int main() {
auto ptr = std::make_shared<MyClass>(); // 必须通过 shared_ptr 构造
auto another_ptr = ptr->get_shared(); // 正确:引用计数+1
ptr->do_something();
another_ptr->do_something();
return 0;
} // 两个 shared_ptr 离开作用域后,对象才被销毁说明:
std::enable_shared_from_this<MyClass>
std::shared_ptr创建,不能是栈对象或裸指针直接构造shared_from_this()前,对象必须已被shared_ptr接管以下几种情况会导致运行时错误或未定义行为:
shared_from_this():此时weak_ptr还未被初始化,会抛出异常。shared_from_this():即使类继承了enable_shared_from_this,但对象不是由shared_ptr管理,调用将失败。this创建shared_ptr:std::shared_ptr<MyClass>(this)多次调用会导致多个独立的引用计数,最终多次析构。正确做法始终是:
std::make_shared<MyClass>()创建对象shared_from_this()
shared_from_this()
这种机制常用于:
shared_ptr传给外部系统,防止对象提前销毁。shared_ptr,同时允许内部方法获取共享所有权。shared_ptr时,可通过shared_from_this()安全获取。基本上就这些。只要记住:继承enable_shared_from_this、用make_shared创建、不在构造/析构中调用shared_from_this,就能安全使用。
以上就是C++如何使用std::shared_from_this_C++智能指针管理与shared_from_this应用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号