weak_ptr 是为了辅助shared_ptr而引入的一种智能指针,它存在的意义就是协助shared_ptr更好的完成工作,我们可以把它比做成一个秘书或助理。
weak_ptr的构造和析构并不会改变引用计数的大小,它可以由一个shared_ptr或weak_ptr的对象构造获得。它没有对“*”和“->”的重载,但可以使用lock获得一个可用的shared_ptr对象。
当面试官问到weak_ptr智能指针的时候,你可以举出一个场景来说明它的作用
场景--------------解决shared_ptr的循环引用问题
我们知道,智能指针shared_ptr采用的是引用计数的方式,下面我们来写一个双向链表。
#include<iostream>
#include<boost/shared_ptr.hpp>
#include<boost/weak_ptr.hpp>
using namespace std;
struct Node
{
int _data;
boost::shared_ptr<Node> _next;
boost::shared_ptr<Node> _prev;
};
int main()
{
boost::shared_ptr<Node> sp1(new Node);
boost::shared_ptr<Node> sp2(new Node);
sp1->_next = sp2;
sp2->_prev = sp1;
system("pause");
return 0;
}
我们暂且将这两块空间称为Node1,和Node2,。我们从上述代码中可知,sp1,sp2,_next,_prev均为shared_ptr类型的智能指针。sp1与sp2->prev都指向Node1,所以sp1的引用计数为2,同理sp1->_next与sp2都指向Node2,所以sp2的引用计数也为2。这是前提,注意,问题来了。