浅析C++单例模式<附实现>

简单工厂模式 请点击 :简单工厂模式浅析

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,这样就违反了我们使用单例模式的初衷了,虽然通过加锁的方式可以有效解决这块的线程同步问题,但是会显得很繁琐。但是我们如果使用饿汉模式的话,就不会出现这个问题,这也是为什么饿汉比懒汉更安全的原因。
感谢阅读,若有不足,欢迎指正。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

All In !!!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值