enable_shared_from_this

  enable_shared_from_this是一个类,继承后的作用是使用shared_ptr<T>管理的对象的this指针以shared_ptr传递到其他函数,当然并不是直接传this,而是通过继承后的一个public方法shared_from_this来生成shared_ptr指向自己的指针。
  大概使用方式(即在下面代码中调用shared_from_this获取指向自身的shared_ptr):

class B;
class A:public enable_shared_from_this{
public:
	shared_ptr<B> get(Key key){
		auto p=_map[key].lock();
		if(!p){
			p.reset(new B(key),bind(&A::deleteB,shared_from_this(),_1); //获取指向this的shared_ptr
			weak_ptr<B>r=p;
			_map[key]=r;
		}
		return p;
	}
private:
	void deleteB(B *b){
		...
		...
 	}
 	map<Key,weak_ptr<B>>_map;
};

int main(){
	shared_ptr<A> p(new A); //注意这里
	...
	...
}

  以下是便是enable_shared_from_this类的源码:(VS2017)

template<class _Ty>
	class enable_shared_from_this
	{	// provide member functions that create shared_ptr to this
public:
	using _Esft_type = enable_shared_from_this;

	_NODISCARD shared_ptr<_Ty> shared_from_this()
		{	// return shared_ptr
		return (shared_ptr<_Ty>(_Wptr));
		}

	_NODISCARD shared_ptr<const _Ty> shared_from_this() const
		{	// return shared_ptr
		return (shared_ptr<const _Ty>(_Wptr));
		}

	_NODISCARD weak_ptr<_Ty> weak_from_this() noexcept
		{	// return weak_ptr
		return (_Wptr);
		}

	_NODISCARD weak_ptr<const _Ty> weak_from_this() const noexcept
		{	// return weak_ptr
		return (_Wptr);
		}

protected:
	constexpr enable_shared_from_this() noexcept
		: _Wptr()
		{	// construct
		}

	enable_shared_from_this(const enable_shared_from_this&) noexcept
		: _Wptr()
		{	// construct (must value-initialize _Wptr)
		}

	enable_shared_from_this& operator=(const enable_shared_from_this&) noexcept
		{	// assign (must not change _Wptr)
		return (*this);
		}

	~enable_shared_from_this() = default;

private:
	template<class _Other,
		class _Yty>
		friend void _Enable_shared_from_this1(const shared_ptr<_Other>& _This, _Yty * _Ptr, true_type);

	mutable weak_ptr<_Ty> _Wptr;
	};

  从源码中,我们可以看到类成员变量中有一个weak_ptr,这也就是实现一个指向自己的shared_ptr的关键,而我们可以看到,似乎类中没有成员方法能够初始化weak_ptr的,所以就只有_Enable_shared_from_this1是我们要关注的点。
  其代码:

template<class _Other,
	class _Yty>
	void _Enable_shared_from_this1(const shared_ptr<_Other>& _This, _Yty * _Ptr, true_type)
	{	// enable shared_from_this
	if (_Ptr && _Ptr->_Wptr.expired())
		{
		_Ptr->_Wptr = shared_ptr<remove_cv_t<_Yty>>(_This, const_cast<remove_cv_t<_Yty> *>(_Ptr));
		}
	}

  该函数出现在enable_shared_from_this中,参数中_This是一个shared_ptr,而_Ptr包含_Wptr,基本上可以推断出,_Yty类型应该是enable_shared_from_this类,而该类的_Wptr在这里被赋值,指向一个_Yty的智能指针。
  那么,这个函数是在哪里调用呢?结合使用方式来看,调用的地方就只有在shared_ptr构建的时候调用,即上面使用方式中,在main函数中使用shared_ptr<A>构建中调用,其中A继承enable_shared_from_this
  即在构建的时候构建一个weak_ptr自身智能指针的观察者,当使用的时候将weak提升至shared,从而达到shared_ptr自身的效果。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值