单例模式介绍
单例模式,是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中一个类只有一个实例。即一个类只有一个对象实例。
简单实现
定义一个单例类,使用类的私有指针变量指向类的唯一实例,并且使用一个共有的静态方法获取该实例。
懒汉模式:即第一次调用该类的实例的时候才产生一个新的该类实例,并在以后仅返回此实例。
头文件singletonpattern.h
#ifndef SINGLETONPATTERN_H
#define SINGLETONPATTERN_H
class SingletonPattern
{
private:
SingletonPattern(); //私有构造函数
public:
~SingletonPattern();
static SingletonPattern* instance();
private:
static SingletonPattern* instance;
};
#endif // SINGLETONPATTERN_H
源文件singletonpattern.cpp
#include "singletonpattern.h"
SingletonPattern* SingletonPattern::_mission_manager = nullptr; //懒汉
SingletonPattern::SingletonPattern()
{
}
SingletonPattern::~SingletonPattern()
{
}
SingletonPattern* SingletonPattern::instance()
{
if(!instance)
{
instance = new SingletonPattern();
}
return instance;
}
饿汉模式: 无论是否调用该类的实例,在程序一开始就产生一个实例,并在以后仅返回此实例。
SingletonPattern* SingletonPattern::_mission_manager = new SingletonPattern(); //饿汉模式
线程安全的单例模式
上面介绍的简单实现方式没有考虑到多线程的安全问题。使用double-check来保证线程安全 thread safety,但是如果处理大量数据的时候,该锁成为严重的性能瓶颈。
SingletonPattern* SingletonPattern::instance()
{
if(!instance)
{
lock();
if(!instance)
{
instance = new SingletonPattern();
}
unlock();
}
return instance;
}
双重锁的目的是减小锁的粒度,只锁住new语句。