boost的shared_ptr循环引用
2014-05-03 14:52
447 查看
boost的智能指针给编程带来了极大的便利,不需要关心内存的释放,不要要调用delete,而且还可以定制delete的方法。其实boost的智能指针是可以当成scope_exit来用的,同样是退出时处理。但是凡事都是有利有弊,boost的shared_ptr如果在循环引用的时候会出现无法释放内存的情况,所谓循环引用就是A智能指针类里存放B的智能指针,B的智能指针类里存放A,将a、b的值互相设置。增加引用计数,在释放的时候由于计数问题,会导致在退出指针域的时候无法进行释放,解决该问题的方案是在类成员中使用弱指针。见如下例子
程序执行,不会调用各自的析构函数。若将其改为weak_ptr则不会引入多余计数的问题,从而可以保证对象被正确释放,看如下修改后的正确代码:
// circleRef.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include <iostream> #include <boost/shared_ptr.hpp> #include <boost/weak_ptr.hpp> using namespace std; class ObjectB; class ObjectA { public: ~ObjectA() { std::cout<<"dctor ~ObjectA"<<std::endl; } void setObjectB(boost::shared_ptr<ObjectB> b) { m_objB = b; } private: boost::shared_ptr<ObjectB> m_objB; }; class ObjectB { public: ~ObjectB() { cout<<"dctor ~ObjectB"<<endl; } void setObjectA(boost::shared_ptr<ObjectA> a) { m_objA = a; } private: boost::shared_ptr<ObjectA> m_objA; }; void test() { boost::shared_ptr<ObjectA> a(new ObjectA); boost::shared_ptr<ObjectB> b(new ObjectB); a->setObjectB(b); b->setObjectA(a); }; int _tmain(int argc, _TCHAR* argv[]) { test(); printf("test "); getchar(); return 0; }
程序执行,不会调用各自的析构函数。若将其改为weak_ptr则不会引入多余计数的问题,从而可以保证对象被正确释放,看如下修改后的正确代码:
// circleRef.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include <iostream> #include <boost/shared_ptr.hpp> #include <boost/weak_ptr.hpp> using namespace std; class ObjectB; class ObjectA { public: ~ObjectA() { std::cout<<"dctor ~ObjectA"<<std::endl; } void setObjectB(boost::shared_ptr<ObjectB> b) { m_objB = b; } private: boost::weak_ptr<ObjectB> m_objB; }; class ObjectB { public: ~ObjectB() { cout<<"dctor ~ObjectB"<<endl; } void setObjectA(boost::shared_ptr<ObjectA> a) { m_objA = a; } private: boost::weak_ptr<ObjectA> m_objA; }; void test() { boost::shared_ptr<ObjectA> a(new ObjectA); boost::shared_ptr<ObjectB> b(new ObjectB); a->setObjectB(b); b->setObjectA(a); }; int _tmain(int argc, _TCHAR* argv[]) { test(); printf("test "); getchar(); return 0; }
相关文章推荐
- 理解 boost::shared_ptr 中所谓的循环引用是如何形成的
- (笔记)为何boost中boost::shared_ptr 循环引用会导致引用计数机制失效
- boost的shared_ptr循环引用(1)
- 关于boost 库 shared_ptr 智能指针的循环引用【2013.10.22】
- boost的shared_ptr循环引用
- boost的shared_ptr循环引用
- std::shared_ptr 和 std::weak_ptr的用法以及引用计数的循环引用问题
- std::shared_ptr 和 std::weak_ptr的用法以及引用计数的循环引用问题
- shared_ptr之循环引用&定置删除器
- weak_ptr shared_ptr与循环引用
- 智能指针的模拟实现shared_ptr 循环引用 定置删除器
- shared_ptr循环引用的例子及解决方法示例
- weak_ptr的作用及应用场景——shared_ptr的循环引用问题
- shared_ptr造成的循环引用&&解决方法和原理(弱引用&&强引用)
- 弱引用weak_ptr 解决shared_ptr的循环引用
- shared_ptr循环引用问题
- c++:分析智能指针shared_ptr存在的循环引用的缺陷
- 在smart_ptr中处理引用计数时使用swap概念(boost::shared_ptr.hpp)
- shared_ptr循环引用问题
- 建议慎用boost::weak_ptr来避免智能指针循环引用