创建this的智能指针

在调试过程中遇到一个导致程序崩溃的BUG,问题出在对象A的Func()方法内部创建了一个指向this的boost::shared_ptr。错误的使用导致Func()退出时析构了对象,而正确的方法是让类继承于boost::enable_shared_from_this<T>,并在需要时使用shared_from_this()创建智能指针。

今天调试的时候发现了一个BUG:A对象的Func(),在调用第二次的时候就崩溃了。

单步发现第二次调用之前,A对象已经被析构。再向前找,发现在Func()内部创建了一个指向this的智能指针p:“boost::shared_ptr<A> p(this)”,这是完全错误的用法。

由于在Func()出栈的时候p的ref count就已经没有了,boost会帮我delete掉this,而这明显不是我所期望的。


其实boost提供了专门为this设计的shared_ptr,用法如下(抄自网络):


#include <boost/enable_shared_from_this.hpp>

class Y: public boost
在 C++ 中,`this` 指针是一个指向当前对象的普通指针,默认情况下它并不具备智能指针的功能如引用计数管理等。如果需要将 `this` 转换为智能指针(例如 `std::shared_ptr` 或 `std::unique_ptr`),则需要注意一些细节。 下面是一种常见的做法: ### 将 `this` 转成 `std::shared_ptr` ```cpp class MyClass { public: std::shared_ptr<MyClass> get_shared_this() { // 需要一个弱指针作为成员变量保存共享所有权信息。 return shared_from_this(); } private: // 使用 enable_shared_from_this 来支持转换功能 std::weak_ptr<MyClass> weak_this; }; ``` 但是上述代码存在一个问题:直接使用 `shared_from_this()` 的前提是该对象必须已经被一个 `std::shared_ptr` 管理了,也就是说创建对象时应通过 `std::make_shared<MyClass>()` 创建而不是普通的栈上分配方式。 因此更标准的做法是让类继承自 `std::enable_shared_from_this<T>`: #### 示例代码 ```cpp #include <memory> #include <iostream> class MyClass : public std::enable_shared_from_this<MyClass> { public: void doSomething() { auto sharedThis = this->get_shared_this(); // 获取当前对象的一个新的 shared_ptr 实例 std::cout << "Smart pointer reference count:" << sharedThis.use_count() << "\n"; } std::shared_ptr<MyClass> get_shared_this() { return shared_from_this(); // 这里就是关键步骤 } }; int main(){ auto obj = std::make_shared<MyClass>(); obj->doSomething(); return 0; } ``` 注意点: - **避免悬挂引用**:不能简单地从堆外实例化转而试图获得 smart ptr 形式的所有权。 - 只有当实际构造过程是由某个形式的 shared_ptr 开始的时候才可以安全调用此函数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值