c++单例模式为啥不在析构函数中释放静态的单例对象,而要加一个内嵌类

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c++单例模式为啥不在析构函数中释放静态的单例对象,而要加一个内嵌类相关的知识,希望对你有一定的参考价值。

析构里delete实例,这个实例释放是会掉自己的析构的,析构里又有delete,这样就无限递归了 参考技术A 单件的实例是存储在堆中的,不会自动析构 参考技术B class GarbageCollector

public:
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++单例模式为啥不在析构函数中释放静态的单例对象,而要加一个内嵌类的主要内容,如果未能解决你的问题,请参考以下文章

单例模式

C++的单例模式怎么释放内存?

C++中的单例模式

C++ 安全单例模式总结

工作和面试中的单例

c++ 单例模式

(c)2006-2024 SYSTEM All Rights Reserved IT常识