c++ 单例模式下的实例自动销毁(单例自动回收器)
2016-05-16 16:17
453 查看
前些日志看到一篇博文,关于C++单例模式下m_pinstance指向空间销毁问题,m_pInstance的手动销毁经常是一个头痛的问题,内存和资源泄露也是屡见不鲜,
能否有一个方法,让实例自动释放。网上已经有解决方案(但是具体实现上表述不足,主要体现在自动析构未能正常运行),那就是定义一个内部垃圾回收类,并且在Singleton中定义一个此类的静态成员。程序结束时,系统会自动析构此静态成员,此时,在此类的析构函数中析构Singleton实例,就可以实现m_pInstance的自动释放。
附上测试代码
运行结果:
参考文档
http://blog.csdn.net/hackbuteer1/article/details/7460019
能否有一个方法,让实例自动释放。网上已经有解决方案(但是具体实现上表述不足,主要体现在自动析构未能正常运行),那就是定义一个内部垃圾回收类,并且在Singleton中定义一个此类的静态成员。程序结束时,系统会自动析构此静态成员,此时,在此类的析构函数中析构Singleton实例,就可以实现m_pInstance的自动释放。
附上测试代码
#include <iostream> using namespace std; class Singleton { public: static Singleton *GetInstance() { if (m_Instance == NULL) { m_Instance = new Singleton(); cout<<"get Singleton instance success"<<endl; } return m_Instance; } private: Singleton(){cout<<"Singleton construction"<<endl;} static Singleton *m_Instance; // This is important class GC // 垃圾回收类 { public: GC() { cout<<"GC construction"<<endl; } ~GC() { cout<<"GC destruction"<<endl; // We can destory all the resouce here, eg:db connector, file handle and so on if (m_Instance != NULL) { delete m_Instance; m_Instance = NULL; cout<<"Singleton destruction"<<endl; system("pause");//不暂停程序会自动退出,看不清输出信息 } } }; static GC gc; //垃圾回收类的静态成员 }; Singleton *Singleton::m_Instance = NULL; Singleton::GC Singleton::gc; //类的静态成员需要类外部初始化,这一点很重要,否则程序运行连GC的构造都不会进入,何谈自动析构 int main(int argc, char *argv[]) { Singleton *singletonObj = Singleton::GetInstance(); return 0; }
运行结果:
参考文档
http://blog.csdn.net/hackbuteer1/article/details/7460019
相关文章推荐
- C++回收回收
- C语言中关键字const、static、volatile的用法分析
- C++对象的内存分布和虚函数表
- R - Milking Time——POJ C语言实现
- 用type定义的枚举类型和结构体
- 一些C++经典书籍
- OC语言笔记(十):OC常见错误集锦
- C++常见问题(二)——虚函数、类与结构、引用与值传递
- OC语言笔记(九):OC内存管理
- loadrunner 修改参数行数限制
- OC语言笔记(八):OC代理、协议和NSDate
- OC语言笔记(七):OC字符串Json、plist、NSNumber和NSValue、KVC
- OC语言笔记(六):OC单例、NSData和文件操作
- OC语言笔记(五):OC封装和复合
- OC语言笔记(四):OC点语法、继承、类别
- OC语言笔记(三):OC数组和字典
- C语言 三级指针的应用
- OC语言笔记(二):OC字符串操作
- c++ 中Hello world的几种写法
- C++的XML编程经验――LIBXML2库使用指南