设计模式(一):c++11单例模式

懒汉式

单例模式是一种设计模式,其目的是保证程序中某个类只能存在一个实例,通常日志系统和程序中的管理类(比如用于管理回调函数的handle_manager等)会以单例模式实现,显然程序不希望这些数据结构存在多个。
c++单例模式有很多种写法,但c++11之后的单例模式,拒绝花里胡哨,直接上代码:

#include <iostream>

class singleton{
public:
    static singleton* getInstance(){
        static singleton p;
        return &p;
    }

    
private:
    singleton(){};
    ~singleton(){};
    singleton(const singleton& another) = delete;
    singleton& operator=(const singleton& another) = delete;
};

int main(){
    singleton* p1 = singleton::getInstance();
    singleton* p2 = singleton::getInstance();
    std::cout << "p1:" << p1 << " p2:" << p2 << std::endl;
    return 0;
}

运行结果如下:
在这里插入图片描述
上面的写法是线程安全的,在需要时才第一次被初始化,被成为懒汉式,这种写法主要是利用了c++11局部静态变量的特性,多个局部静态变量同时初始化时,只有一个能进入初始化过程,其余被阻塞直到初始化完成,由于局部静态变量不会被销毁,多次访问访问的是同一个变量。
需要注意的是,上面的写法getInstance()返回值必须是指针,否则返回值会被另一个变量接收通过赋值运算符接收,而赋值运算符已经被我们显式地删除,因此编译时将报错,如下图。
在这里插入图片描述

饿汉式

下面是饿汉单例模式写法:


class singleton{
public:
    static singleton* getInstance(){
        return &p;
    }
private:
    singleton(){};
    ~singleton(){};
    static singleton p;
    
    singleton(const singleton& another) = delete;
    singleton& operator=(const singleton& another) = delete;
};

singleton singleton::p;


int main(){
    singleton* p1 = singleton::getInstance();
    singleton* p2 = singleton::getInstance();
    std::cout << "p1:" << p1 << " p2:" << p2 << std::endl;
    return 0;
}

运行结果如下:
在这里插入图片描述
饿汉式利用了类外初始化,同样是线程安全的。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值