智能指针根据指向对象的指针个数是否为0判断是否释放对象。该过程是在指针调用析构函数的时候发生,可见智能指针本质上也是一个对象。一个具有指针特性的对象。析构时默认调用delete进行对象的释放,如果创建的是一些特别的对象,比如数组,连接等,必须在创建智能指针时提供一个删除器。shared_ptr定制删除器: shared_ptr<type> ptr_obj( new type(), deleter); unique定制删除器需要使用模板:unique_ptr<type, decltype(deleter)*> ptr_obj(new type(), deleter);
C++ 11提出了弱引用的概念,与strong reference(shared_ptr)相对的一个概念。使用的类型为:boost::weak_ptr.
weak_ptr首先是一个模板,其次是无法直接访问对象,使用时必须将其转换成shared_ptr,最后这种指针的个数并不会影响对象的自动释放(不会影响对象的 引用计数)。
如何使用weak_ptr: 两种方法,一种是使用构造函数,另一种是使用weak_ptr::lock方法。第二种比较常用。如果对象已经被释放,两种方法使用weak_ptr访问对象分别会返回异常boost::bad_weak_ptr和空的shared_ptr。另外weak_ptr的unique和reset会结合使用。
shared_ptr<int> p(new int(6));
weak_ptr<int> q = p;
//other function
if(shared_ptr<int> r = q.lock()){
//do something
}else{
//do other
}
4. weak_ptr的特性与shared_ptr的最大的区别在于两点,一是weak_ptr无法直接访问对象,二是weak_ptr不会对对象的释放产生影响。那么,什么时候需要使用weak_ptr呢?考虑下面一个场景,进程从队列中读取数据,经过一系列操作之后,发送回应给这个队列。进程需要hold队列的引用。为了防止队列提前destroy。可以使用shared_ptr.但是如果处理时间比较长,此时队列可能早就不再使用,被close了,那么,可能会严重的推迟队列的释放,此时可以用weak_ptr保存上述引用。
shared_ptr<queue> q;
struct{
weak_ptr<queue> q;
//other information about message
}MessageType;
MessageType m;
m=q->Get();
m.q = q;
....
....
....
if(shared_ptr<queue> r = m.q.lock()){
r.send(data);
}