C++智能指针std::shared_ptr循环引用坑

前言

        本章对智能指针std::shared_ptr是如何形成循环引用做出说明。智能指针的循环引用会导致内存得不到正确的释放。

示意图

 代码

#include<memory>

// 定义两个类
class B;
class A
{
    public:
    std::shared_ptr<B> pointer;        // 指向B类的智能指针对象
};

class B
{
    public:
    std::shared_ptr<A> pointer;        // 指向A类的智能指针对象
};

int main()
{
    // 定义两A、B两个类的智能指针对象
    std::shared_ptr pA = std::make_shared<A>();
    std::shared_ptr pB = std::make_shared<B>();
    
    // 此时智能指针pA和pB的引用计数都是1
    // ---
    pA -> pointer = pB;                // 将pB赋值给pA的成员对象B类智能指针。此时,pB引用计数为2
    
    pB -> pointer = pA;                // 将pA赋值给pB的成员对象A类智能指针。此时,pA引用计数为2
   
    return 0;
}

        当函数结束,智能指针pA,pB生命周期结束,引用计数各 -1 ,所以pA,pB各自指向的内存不会被释放,造成内存泄漏。

        如果不循环指向

...
    std::shared_ptr pA = std::make_shared<A>();    // pA引用计数 1
    std::shared_ptr pB = std::make_shared<B>();    // pB引用计数 1
    pA -> pointer = pB;                           // pB引用计数 2
 ...

        当生命周期结束,pB 引用计数-1,为1,不会被释放。pA 引用计数 -1 ,为0,pA指向的空间将会被释放,pA指向的A对象中的成员B智能指针对象poninter 生命周期也将会结束,引用计数再-1,所以pB指向的空间也会被释放。所以shared_ptr只有循环引用时才会产生内存泄漏风险。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_虚竹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值