C++11之智能指针

shared_ptr

shared_ptr是带引用计数的指针。只有当引用计数为 0 的时候,才会释放所指的对象。
shared_ptr 不需要程序员手工调用 AddRef 和 Release 函数,进一步减小了内存出错的可能性。

int main( )
{
    std::shared_ptr<double> p_first(new double);  // 引用计数=1
    {
        std::shared_ptr<double> p_copy = p_first ; // 引用计数+1=2
        *p_copy = 1.234;
    }  // 局部变量p_copy释放,引用计数-1=1,double对象仍存在
    return 0;  // p_first释放,指向double的shared_ptr引用计数=0,double对象被释放
}

使用 shared_ptr 要注意的可能会引起循环引用的代码结构。比如:有对象 A 和 B,其各有一个指针指向对方。

class A
{
  ...
  std::shared_ptr<B> pB;
  ...
};
class B
{
  ...
  std::shared_ptr<A> pA;
  ...
};
int main () {
  std::shared_ptr<A> a(new A());
  std::shared_ptr<B> b(new B());

  a->b = b; 
  b->a = a;

  return 0;
}

在程序运行结束时,A,B的对象都不能够被正确释放,因为:
如果释放A,但B内部仍存有指向A的一个引用计数;
如果释放B,但A内部仍存有指向B的一个引用计数。

weak_ptr

类似线程安全方面的死锁问题,为了解决循环引用问题,可以使用 weak_ptr。
weak_ptr并不拥有它所指向的对象,因此不影响该对象的销毁与否。
对上例做如下调整后,解决对象不能正常销毁的问题。

class A
{
  ...
  std::weak_ptr<B> pB;
  ...
};
class B
{
  ...
  std::weak_ptr<A> pA;
  ...
};
int main () {
  std::shared_ptr<A> a(new A());
  std::shared_ptr<B> b(new B());

  a->b = b; 
  b->a = a;

  return 0;
}

weak_ptr的特点:

  • weak_ptr指向的是一个被shared_ptr所指向的对象。
  • weak_ptr可以用来决定该对象是否已被销毁。
  • weak_ptr不能被直接解引用;

想要访问其内部所保存的指针,必须通过shared_ptr,有两种方法:
第一,以weak_ptr为参数,构造一个shared_ptr.

shared_ptr<B> pB(a->b);
pB->foo();

第二,通过weak_ptr的lock()成员函数,返回一个shared_ptr

shared_ptr<B> pB = a->b.lock();
pB->foo();
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 原作者:Babu_Abdulsalam 本文翻译自CodeProject,转载请注明出处。 引入### Ooops...
    卡巴拉的树阅读 30,286评论 13 74
  • 1. 什么是智能指针? 智能指针是行为类似于指针的类对象,但这种对象还有其他功能。 2. 为什么设计智能指针? 引...
    MinoyJet阅读 3,838评论 0 1
  • 12.1 智能指针 智能指针行为类似普通指针,但它负责自动释放所知的对象。 #include <memory> s...
    龙遁流阅读 2,929评论 0 1
  • 《影响力》主要是讲述一些善于利用顺从原理的人来达到让我们走进他们的计划进而达成自己的目的。这些顺从原理包括:互惠,...
    小呆呆阅读 3,118评论 0 0
  • 野兽派 马蒂斯 21岁才学画 戴帽子的妇人 我不是在创作一个女人,而是在画一幅画。 二徐之争 潘玉良 关紫兰 ...
    唐宝宝宝宝阅读 1,387评论 0 0

友情链接更多精彩内容