c++单例模式为啥不在析构函数中释放静态的单例对象,而要加一个内嵌类
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c++单例模式为啥不在析构函数中释放静态的单例对象,而要加一个内嵌类相关的知识,希望对你有一定的参考价值。
析构里delete实例,这个实例释放是会掉自己的析构的,析构里又有delete,这样就无限递归了 参考技术A 单件的实例是存储在堆中的,不会自动析构 参考技术B class GarbageCollectorpublic:
GarbageCollector()
qDebug() << "init GarbageCollector";
~GarbageCollector()
if (Variable_Manager::sVariableManager != nullptr)
qDebug() << "del GarbageCollector";
delete Variable_Manager::sVariableManager;
Variable_Manager::sVariableManager = nullptr;
;
static GarbageCollector gc;//作为静态,会在程序内生存。作为栈对象,会在程序结束自动析构(顺便把sVariableManager堆对象带走)
代码内嵌在单例的类中 参考技术C 单例模式通过类本身来管理其唯一实例,这种特性提供了解决问题的方法。唯一的实例是类的一个普通对象,但设计这个类时,让它只能创建一个实例并提供 对此实例的全局访问。唯一实例类Singleton在静态成员函数中隐藏创建实例的操作。习惯上把这个成员函数叫做Instance(),它的返回值是唯 一实例的指针。
定义如下:
class CSingleton
//其他成员
public:
static CSingleton* GetInstance()
if ( m_pInstance == NULL ) //判断是否第一次调用
m_pInstance = new CSingleton();
return m_pInstance;
private:
CSingleton();
static CSingleton * m_pInstance;
;追问
我说的是释放
C++的单例模式的几种实现方式解析
单例模式有两种实现模式:
1)懒汉模式: 就是说当你第一次使用时才创建一个唯一的实例对象,从而实现延迟加载的效果。
2)饿汉模式: 就是说不管你将来用不用,程序启动时就创建一个唯一的实例对象。
所以,从实现手法上看,懒汉模式是在第一次使用单例对象时才完成初始化工作。因为此时可能存在多线程竞态环境,如不加锁限制会导致重复构造或构造不完全问题。
饿汉模式则是利用外部变量,在进入程序入口函数之前就完成单例对象的初始化工作,此时是单线程所以不会存在多线程的竞态环境,故而无需加锁。
以下是典型的几种实现
一、 懒汉模式,标准的 ”双检锁“ + ”自动回收“ 实现
?
1
以上是关于c++单例模式为啥不在析构函数中释放静态的单例对象,而要加一个内嵌类的主要内容,如果未能解决你的问题,请参考以下文章 |