假如有一个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的时候传这个可不可以?)
参考来源
-
https://blog.youkuaiyun.com/caoshangpa/article/details/79392878
-
陈硕书P51,即1.11.1节
-
std::enable_shared_from_this 有什么意义? - 知乎 https://www.zhihu.com/question/30957800