本文主要是介绍智能指针-share_ptr循环引用导致内存泄漏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
有两个栈内share_ptr对象aptr/bptr分别指向两个对象A/B,A/B两个对象互相使用一个shared_ptr成员变量指向对方A/B,会造成循环引用。
当两个栈内存离开main函数作用域后只是对象对象A/B引用计数减少1,但A/B对象的引用计数并没有减少到0,因此内存不会被share_ptr的析构函数给释放,造成内存泄漏
#include<iostream>
#include<memory>
using namespace std;class B;class A {
public:~A();void setS(const shared_ptr<B> &bp);
private:shared_ptr<B> bPtr;
};void A::setS(const shared_ptr<B> &bp)
{bPtr = bp;
}A::~A()
{cout << "~A" << endl;
}class B {
public:~B();void setS(const shared_ptr<A> &ap);
private:shared_ptr<A> aPtr;
};void B::setS(const shared_ptr<A> &ap)
{aPtr = ap;
}B::~B()
{cout << "~B" << endl;
}int main()
{cout << "Hello world!" << endl;shared_ptr<A> aptr = make_shared<A>();shared_ptr<B> bptr = make_shared<B>();int aRefCnt = aptr.use_count();int bRefCnt = bptr.use_count();int aRefCntAfter = -1;int bRefCntAfter = -1;if (aptr != nullptr && bptr != nullptr) {aptr->setS(bptr);bRefCntAfter = bptr.use_count(); // 2bptr->setS(aptr);aRefCntAfter = aptr.use_count(); // 2}// 所以申请的对象现在引用计数都是2,,main函数结束后,// 虽局部变量aptr和bptr会栈回收,但指向的对象应用计数仍为1,永远不会调用析构来释放内存。return 0;
}
参考:
https://www.cnblogs.com/wxquare/p/4759020.html
https://www.cnblogs.com/ymd12103410/p/11136584.html
这篇关于智能指针-share_ptr循环引用导致内存泄漏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!