首次接触单类,感觉很好奇。单类顾名思义就是只允许存在一个实例的就叫单类。那么只允许一个实例我们可以设置一个全局的对象来供我们使用,又何必使用到单类?确实如果你能保证你能在其他地方不再设置一个全局对象。单类就是无论如何我只有一个实例对象,并且自己来管理,将构造函数设置成私有的,那么就不会让你任意的构造实例对象。
一般来说单类分为两种,一种是饿汉模式,一种是懒汉模式。
饿汉模式可用于访问量较大,访问的线程较多时的情景,可以实现更好的性能,使用的正是以空间换时间的思想。
懒汉模式在访问量比较小时使用,则是以时间换空间的思想。
说白了这两种模式的区别在于初始化。饿汉模式一开始就将对象初始化好,并且只有一份,初始化的时候分配空间,在调用的时候节省了时间(不再分配空间)。懒汉模式则是在调用的时候进行初始化分配空间,并且如果多线程使用还得加锁,这样虽然开始的时候减少了使用空间但是在使用的时候却延长了时间。
饿汉模式实例:
template <class T>
class singleton
{
private:
singleton()
{}
static T* _instance;
public:
static T* GetInstance();
};
template <class T>
T* singleton<T>::GetInstance()
{
return _instance;
}
template <class T>
T* singleton<T>::_instance = new T();
懒汉模式实例:
template <class T>
class singleton
{
private:
singleton()
{}
static T* _instance;
static pthread_mutex_t mutex;
public:
static T* GetInstance();
};
template <class T>
T* singleton<T>::GetInstance()
{
if(_instance == NULL)
{
pthread_mutex_lock(&mutex);
if( _instance == NULL)
{
_instance = new T();
}
pthread_mutex_unlock(&mutex);
}
return _instance;
}
template <class T>
pthread_mutex_t singleton<T>::mutex = PTHREAD_MUTEX_INITIALIZER;
template <class T>
T* singleton<T>::_instance = NULL;
如果你的程序讲究效率,建议使用饿汉模式,如果你的程序开始初始的内存很多,你想减少开销,后期访问又不多的情况下那么建议你使用懒汉模式。