分析:
1.单例模式表明该类只有一个实例被创建,首先将类的构造方法设置为私有,然后写一个public静态函数用来创建实例,利用该类的一个静态指针来保存唯一实例,创建之前先判断是否已经存在,如果已经创建过了就不再创建。
2.考虑到线程安全和异常安全可以在静态函数中加锁。
3.考虑在合适的时机析构创建的实例,因此在该类中定义一个内嵌类delInstance,然后在singleton中添加一个delInstance的静态成员,在程序运行结束后系统会调用静态成员的析构函数,删除单例的唯一实例。
具体代码如下:
class Singleton{ public: static Singleton* createInstance(); private: Singleton(){cout<<"Instance created!\n";} static Singleton* Instance; //内嵌类 class delInstance{ public: ~delInstance() { if(Instance!=NULL) delete Instance; } }; static delInstance del; }; Singleton* Singleton::Instance=NULL; Singleton::delInstance Singleton::del; Singleton* Singleton::createInstance() { if(NULL==Instance) { Lock(); if(NULL==Instance) Instance=new Singleton(); Unlock(); } return Instance; }
之所以在createInstance函数里面对Instance 是否为空做了两次判断,因为该方法调用一次就产生了对象,Instance == NULL 大部分情况下都为false,如果按照原来的方法,每次获取实例都需要加锁,效率太低。而改进的方法只需要在第一次
调用的时候加锁,可大大提高效率。
时间: 2024-11-15 08:52:36