简单工厂模式 请点击 :简单工厂模式浅析
C++单例模式
什么是单例模式?
精简的说就是:这个类能只有一个实例化的对象。
如何实现实例化?
既然只能有一个实例化对象,那么就要防止被多次实例化,怎么防止呢?我们就把构造函数私有化或者受保护,这样构造函数就无法被外部调用,只能被类内部的成员函数调用,所以我们需要定义一个公有函数来供外部使用,这个公有函数返回一个对象,为了保证多次调用这个公有函数都会返回同一个对象,就需要将这个对象设置为静态的。
简单总结一下需要注意三点:
1:构造函数需要私有化或者受保护;
2:定义静态对象;
3;定义公有函数,该公有函数也定义为静态;
于是就有了以下单例模式的代码:
class A
{
protected:
A()
{
}
private:
static A *p;
public:
static A *SSS();
};
A* A::p = NULL;
A* A::SSS()
{
if (p == NULL)
{
p = new A();
}
return p;
}
大家可以看到,以上代码里的对象p一开始并没有被初始化,而是在调用公有函数SSS时才被初始化,这就是单例模式里的懒汉模式,顾名思义就是懒,不到万不得已不实例化,懒汉模式是用时间来换空间的。
单例模式中另外一种模式是饿汉模式,一样的理解,就是饿的不行了,,一开始就会给对象初始化,使用空间换时间的。
下面的代码就是饿汉模式
class A
{
protected:
A()
{
}
private:
static A *p;
public:
static A *SSS();
};
A* A::p = new A();
A* A::SSS()
{
return p;
}
总结二:
饿汉模式比懒汉模式更安全,主要体现在线程安全上,在这大致记一下,防止后面遗忘:
懒汉模式下,若多个线程在使用,线程1正在判断p是否为空,然后初始化p,这个时候线程2也同时判断P是否为空,也初始化了一次p,这样就违反了我们使用单例模式的初衷了,虽然通过加锁的方式可以有效解决这块的线程同步问题,但是会显得很繁琐。但是我们如果使用饿汉模式的话,就不会出现这个问题,这也是为什么饿汉比懒汉更安全的原因。
感谢阅读,若有不足,欢迎指正。