[zz] C++智能指针循环引用解决
2013-03-04 13:44
489 查看
转载自:http://blog.csdn.net/segen_jaa/article/details/8080167
参考文章:/article/4658813.html。
前言:C++中智能指针的引入,使得开发人员在与内存的斗争中占据上峰。然而凡事都不会尽善尽美,智能指针的循环引用缺陷还是会引发令人谈虎色变的内存泄露。本文的内容就是讲述,如何解决循环引用带来的内存问题。
背景:智能指针采用Boost库,语言C++,开发工具VS2005,示例程序为Win32程序。
关于Boost库的使用,可见另一篇文章http://blog.csdn.net/segen_jaa/article/details/7407404。
循环引用示例
[cpp] view plaincopy
#include "stdafx.h"
#include <string>
#include <iostream>
#include <boost/shared_ptr.hpp>
#include <boost/weak_ptr.hpp>
using namespace std;
using namespace boost;
class CCycleRef
{
public:
~CCycleRef()
{
cout <<"destroying CCycleRef"<<endl;
}
public:
shared_ptr<CCycleRef> selfRef;
};
void CycleRefTest()
{
shared_ptr<CCycleRef> cyclRef(new CCycleRef());
cyclRef->selfRef = cyclRef;
cout<<"reference count:"<<cyclRef.use_count()<<endl;
}
int _tmain(int argc, _TCHAR* argv[])
{
CycleRefTest();
return 0;
}
运行结果:
reference count:2
创建的CCycleRef对象没有释放掉。
原因是CCycleRef类进行了自引用,引用计数增加所致,类图如下。
循环引用解决
引入weak_ptr弱引用指针即可解决循环引用问题。weak_ptr不会修改引用计数。
修改CCycleRef类。
[cpp] view plaincopy
class CCycleRef
{
public:
~CCycleRef()
{
cout <<"destroying CCycleRef"<<endl;
}
public:
weak_ptr<CCycleRef> selfRef;
};
运行结果
reference count:1
destroying CCycleRef
创建的CCycleRef对象已被释放。
参考文章:/article/4658813.html。
前言:C++中智能指针的引入,使得开发人员在与内存的斗争中占据上峰。然而凡事都不会尽善尽美,智能指针的循环引用缺陷还是会引发令人谈虎色变的内存泄露。本文的内容就是讲述,如何解决循环引用带来的内存问题。
背景:智能指针采用Boost库,语言C++,开发工具VS2005,示例程序为Win32程序。
关于Boost库的使用,可见另一篇文章http://blog.csdn.net/segen_jaa/article/details/7407404。
循环引用示例
[cpp] view plaincopy
#include "stdafx.h"
#include <string>
#include <iostream>
#include <boost/shared_ptr.hpp>
#include <boost/weak_ptr.hpp>
using namespace std;
using namespace boost;
class CCycleRef
{
public:
~CCycleRef()
{
cout <<"destroying CCycleRef"<<endl;
}
public:
shared_ptr<CCycleRef> selfRef;
};
void CycleRefTest()
{
shared_ptr<CCycleRef> cyclRef(new CCycleRef());
cyclRef->selfRef = cyclRef;
cout<<"reference count:"<<cyclRef.use_count()<<endl;
}
int _tmain(int argc, _TCHAR* argv[])
{
CycleRefTest();
return 0;
}
运行结果:
reference count:2
创建的CCycleRef对象没有释放掉。
原因是CCycleRef类进行了自引用,引用计数增加所致,类图如下。
循环引用解决
引入weak_ptr弱引用指针即可解决循环引用问题。weak_ptr不会修改引用计数。
修改CCycleRef类。
[cpp] view plaincopy
class CCycleRef
{
public:
~CCycleRef()
{
cout <<"destroying CCycleRef"<<endl;
}
public:
weak_ptr<CCycleRef> selfRef;
};
运行结果
reference count:1
destroying CCycleRef
创建的CCycleRef对象已被释放。
相关文章推荐
- 【C++】智能指针简述(五):解决循环引用的weak_ptr
- C++智能指针(三):weak_ptr--解决shared_ptr循环引用问题
- C++智能指针循环引用解决
- 智能指针与弱指针解决循环引用
- c++:分析智能指针shared_ptr存在的循环引用的缺陷
- 关于c++ 智能指针及 循环引用的问题
- C++ — 智能指针的简单实现以及循环引用问题
- C++ 智能指针——简单实现以及循环引用问题
- 智能指针的循环引用和如何解决循环引用
- [C++] 智能指针与循环引用
- c++ 智能指针及 循环引用问题
- c++ 智能指针及 循环引用问题
- c++智能指针循环引用带来的问题及解决方案
- C++ — 智能指针的简单实现以及循环引用问题
- c++ 智能指针及 循环引用问题
- 基于引用计数的智能指针为什么会发生循环引用
- C++文本查询程序 定义类管理数据 用引用共享数据 不用智能指针 C++Primer练习12.27
- C++文本查询程序 定义类管理数据 用引用共享数据 不用智能指针 C++Primer练习12.27
- 智能指针的交叉引用问题及解决方法
- 【C++】智能指针之引用计数的实现