4——创建型模式之单例模式

最后更新于:2022-04-01 20:10:34

**定义**:单例模式(SingletonPattern),保证一个类仅有一个实例,并提供一个访问它的全局访问点。 类型:创建型模式 类图: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-08-19_57b6abd31cbe8.jpg) **概述**:       在很多比较大型的程序中,全局变量经常被用到。如果不用全局变量,那么在使用到的模块中,都需要用参数将全局变量传入,这是非常麻烦的。虽然要减少使用全局变量,但是如果需要,还是要用。单例模式就是对传统的全局的一种改进。单例可以做到延时实例化,即在需要的时候才进行实例化。针对一些大型的类,延时实例化是有好处的。      需要注意的是,在C#,Java中,有饿汉单例模式(即在声明变量的时候就初始化)和懒汉模式(在需要使用的时候再初始化)。而在GoF的书中,只讲到了懒汉模式,这是因为C++的静态变量在初始化时具有不确定性。同一个类中的静态变量初始化与其声明顺序一致,但是不同类中的静态变量初始化顺序却是不确定的。      另外在多线程中,需要注意访问的临界区,需要加Lock用以控制。 代码:添加了一个静态对象用来处理内存垃圾回收。 ~~~ // C++ class CSingleton {    // 私有构造函数,不被允许直接构造对象 private:    CSingleton()    {    } public:    static CSingleton* GetInstance()    {        if (NULL == m_pSingleton)            m_pSingleton = new CSingleton();        return m_pSingleton;    }    void SetIdx(int _nIdx)    {        m_nIdx = _nIdx;    }    int GetIdx()    {        return m_nIdx;    } private:    int m_nIdx;    static CSingleton* m_pSingleton; public:    class CRecycle    {    public:        ~CRecycle()        {            if (NULL !=CSingleton::m_pSingleton)            {                deleteCSingleton::m_pSingleton;            }        }    };    static CRecycle m_recycle; }; // 静态成员变量的初始化 CSingleton*CSingleton::m_pSingleton = NULL; CSingleton::CRecycleCSingleton::m_recycle; int _tmain(int argc,_TCHAR* argv[]) {    CSingleton::GetInstance()->SetIdx(1);   return0; } ~~~ 优缺点: 1. 优点,能够灵活地控制什么时候去访问。 1. 缺点,和其他模块耦合性太强,作为全局变量的通病。 参考资料: 1. 《设计模式——可复用面向对象软件基础》 1. 《Java与模式》 1. 《大话设计模式》
';