C++ weak pointer

智能指针根据指向对象的指针个数是否为0判断是否释放对象。该过程是在指针调用析构函数的时候发生,可见智能指针本质上也是一个对象。一个具备指针特性的对象。析构时默认调用delete进行对象的释放,若是建立的是一些特别的对象,好比数组,链接等,必须在建立智能指针时提供一个删除器。shared_ptr定制删除器: shared_ptr<type> ptr_obj( new type(), deleter); unique定制删除器须要使用模板:unique_ptr<type, decltype(deleter)*> ptr_obj(new type(), deleter);数组

  1. C++ 11提出了弱引用的概念,与strong reference(shared_ptr)相对的一个概念。使用的类型为:boost::weak_ptr.函数

  2. weak_ptr首先是一个模板,其次是没法直接访问对象,使用时必须将其转换成shared_ptr,最后这种指针的个数并不会影响对象的自动释放(不会影响对象的 引用计数)。指针

  3. 如何使用weak_ptr: 两种方法,一种是使用构造函数,另外一种是使用weak_ptr::lock方法。第二种比较经常使用。若是对象已经被释放,两种方法使用weak_ptr访问对象分别会返回异常boost::bad_weak_ptr和空的shared_ptr。另外weak_ptr的unique和reset会结合使用。code

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保存上述引用。orm

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);
}
相关文章
相关标签/搜索