弱引用指针weak_ptr是用来监视shared_ptr的生命周期,是shared_ptr的一个助手。weak_ptr没有重载操作符*和->,因为它不与shared_ptr共享指针,不能操作资源,主要是通过shared_ptr获得资源的检测权,它的构造不会增加引用计数,它的析构也不会减少引用计数,纯粹只是作为一个旁观者来监视shared_ptr中管理的资源是否存在。weak_ptr还可以用来返回this指针和解决循环引用的问题。
1、weak_ptr构建
当我们创建一个weak_ptr时,需要用一个shared_ptr实例来初始化weak_ptr,由于是弱共享,weak_ptr的创建并不会影响shared_ptr的引用计数值。可以通过use_count()方法来获得当前观测资源的引用计数。
int main()
{
std::shared_ptr<Int> pInta(new Int(10));
std::weak_ptr<Int> wp(pInta);
cout<<wp.use_count()<<endl;
//返回被管理该对象的shared_ptr指针的数量
//在调用的瞬间共享被管理对象所有权的shared_ptr实例数量。
}
2、通过expired()方法来判断所观测的资源是否已经被释放
int main()
{
std::shared_ptr<Int> sp(new Int(10));
std::weak_ptr<Int> wp(sp);
//sp.reset();
if(wp.expired())
{
cout<<"weak_ptr无效,所监视的智能指针已经被释放"<<endl;
}
else
{
cout<<"weak_ptr有效"<<endl;
}
return 0;
}
3、通过lock方法来获取所监视的shared_ptr
weak_ptr并没有重载operator->和operator*操作符,因此不可直接通过weak_ptr使用对象,典型的用法是调用其lock函数来获得shared_ptr实例,进而访问对象。
std::weak_ptr<Int> gw;
void func()
{
if(!gw.expired())
{
cout<<"gw is valid"<<endl;
auto spt=gw.lock();//创建管理被引用的对象的shared_ptr
spt->PrintInt();
}
else
{
cout<<"gw is expired"<<endl;
}
}
int main()
{
{
shared_ptr<Int> sp=make_shared<Int>(42);
gw=sp;
func();
}
func();
return 0;
}
4、理解weak_ptr工作原理
int main()
{
std::weak_ptr<Int> wp;
{
std::shared_ptr<Int> pInta(new Int(10));
wp=pInta;
std::shared_ptr<Int> pIntb(pInta);
{
std::shared_ptr<Int> pIntc(pInta);
cout<<wp.use_count()<<endl;
}
}
if(!wp.expired())
{
cout<<wp.use_count()<<endl;
}
return 0;
}