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会结合使用。

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);
}


转载于:https://my.oschina.net/u/2368952/blog/416606

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值