std::enable_shared_from_this 有什么意义

8 篇文章 0 订阅

假如有一个stock和stockFactory类,代表股票和股票池,stockFactory里输入股票代码查询是否有stock,有则返回,没则创建并返回stock,这里用一个std::map来建立映射;

而股票如果用完了要自己析构,要顺便把stockFactory里map的内容也析构掉;

因为Stock采用shared_ptr来管理的,要让Stock析构的时候顺便调用stockFactory::delete(Stock),这样要在Stock的析构函数里调用,这样代码难以实现,还有另一种办法,设置shared_ptr的析构时的运行的函数

设置shared_ptr指向对象析构时运行的函数叫reset,即shared_ptr_object.reset(&function_needed_to_be_called),而传入stockFactory的成员函数,需要传std::bind,std::bind传入成员函数需要传this指针,

在多线程环境下,调用shared_ptr的析构时候,也就是stock对象的析构时,这个this指针指向也就是stockFactory可能已经被析构了,shared_ptr析构的时候调用到函数this->delete(stock)),这样会发生core dump(访问非法空间),一个想法是我们不传this指针,而是传智能指针来当上面reset()里std::bind的参数

所以怎么获得this的只能指针呢,shared_ptr<StockFactory*>(this)吗,为什么不用这个呢因为,这样这个std::bind里的只能指针引用计数是1,不能和其他引用次数共享,而最后还是会出现stockFactory析构掉而stock析构时core dump

(已经析构了,第二次调用shared_ptr->也还是会有问题吧,怎么判断shared_ptr对应的已经被析构了)

最后再总结下enable_shared_from_this的作用:

一个已被shared_ptr sp1管理的对象stockFactory,被enalbe_shared_from_this继承后,使用shared_from_this 代替this,就可返回和sp1共享引用计数的shared_ptr

----二更

总结一句话,当非成员函数bind成员函数的时候,需要传入this指针,而如果这个类已经被析构,则会core dump,于是用一个shared_ptr来,而shared_ptr不能共享的指向this,所以就用这个shared_from_this,

(那如果自己实现,一个类用一个shared_ptr成员指向自身,要传this的时候传这个可不可以?)

 

参考来源

  1. https://blog.csdn.net/caoshangpa/article/details/79392878

  2. https://www.cnblogs.com/xiezhw3/p/4099948.html

  3. 陈硕书P51,即1.11.1节

  4. std::enable_shared_from_this 有什么意义? - 知乎 https://www.zhihu.com/question/30957800

`std::enable_shared_from_this` 是一个模板类,其目的是为了解决在一个对象中保存 shared_ptr 的问题。它是 C++11 引入的一个特性。 在使用 `std::shared_ptr` 时,我们往往需要在对象中保存一个 `std::shared_ptr` 的副本,这样才能确保对象在使用完毕后不会被提前销毁。但是这种方式会导致一些问题,比如我们无法防止用户直接使用裸指针来操作对象,从而导致对象被提前销毁等问题。 这时候,我们可以使用 `std::enable_shared_from_this` 来解决这些问题。具体而言,我们需要继承 `std::enable_shared_from_this`,然后在对象中使用 `shared_from_this()` 方法来获取一个指向当前对象的 `std::shared_ptr`。 下面是一个示例代码: ```c++ #include <iostream> #include <memory> class MyClass : public std::enable_shared_from_this<MyClass> { public: std::shared_ptr<MyClass> get_shared_ptr() { return shared_from_this(); } }; int main() { std::shared_ptr<MyClass> p(new MyClass); std::shared_ptr<MyClass> q = p->get_shared_ptr(); std::cout << "p.use_count() = " << p.use_count() << std::endl; std::cout << "q.use_count() = " << q.use_count() << std::endl; return 0; } ``` 在这个示例中,我们定义了一个名为 `MyClass` 的类,并且继承了 `std::enable_shared_from_this`。然后,我们在类中定义了一个名为 `get_shared_ptr()` 的方法,该方法使用了 `shared_from_this()` 方法来获取一个指向当前对象的 `std::shared_ptr`。在 `main()` 函数中,我们先创建了一个 `std::shared_ptr` 对象 `p`,然后通过 `p` 调用 `get_shared_ptr()` 方法获取了一个指向同一个对象的 `std::shared_ptr` 对象 `q`。最后,我们输出了 `p` 和 `q` 的引用计数,可以看到它们的引用计数都是 2。 需要注意的是,在使用 `std::enable_shared_from_this` 时,我们需要确保对象已经被一个 `std::shared_ptr` 管理,否则使用 `shared_from_this()` 方法会导致程序崩溃。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值