c++设计模式

单例模式

若有class A,整个程序中保证A类只有一个对象。

1.为了保证只有一个实例,那么就不能让A类随意创建对象,也就不能调用构造函数,那么就需要把构造函数私有化

2.需要私有的静态当前类的指针成员变量

私有:保证无法在类外对成员变量进行操作。

静态:保证类的对向只有一个。

3.需要一个函数GetInstance()来返回单例模式的对象,因为构造函数私有化所以无法在类外构造对象。那么GetInstance()函数就作为静态接口 ,直接通过类名来调用函数。由于静态函数只能调用静态变量,因此A类中的成员变量也需要是静态。由于成员变量是静态的,所以要在类外进行初始化。

4.**对象释放的问题:**由于单例模式只有一个对象,所以占用内存很少,不用专门释放内存,等到程序结束后系统将所有内存回收即可。

懒汉模式

第一次调用获取实例的函数GetInstance()时才创建对象。

cpp 复制代码
//懒汉模式
class SingletonLazy{
private:
	//1.构造函数私有化
    SingletonLazy(){}
    //2.私有的静态当前类的指针成员变量
    static SingletonLazy* pSingleton;
    
public:
	//3.获取对象的静态接口
    static SingletonLazy* GetInstance(){
        if(pSingleton == nullptr){
            pSingleton = new SingletonLazy;
        }
        return pSingleton;
    }
};
SingletonLazy* SingletonLazy::pSingleton = nullptr;

饿汉模式

直接在类外初始化对象时直接创建。在main函数执行之前就已经创建好对象。

cpp 复制代码
//饿汉模式
class SingletonHungry{
private:
    //1.构造函数私有化
    SingletonHungry(){}
    //2.私有的静态当前类的指针成员变量
    static SingletonHungry* pSingleton;

public:
    //3.获取对象的静态接口
    static SingletonHungry* GetInstance(){
        return pSingleton;
    }
};
SingletonHungry* SingletonHungry::pSingleton = new SingletonHungry;

单例模式遇到多线程

1.懒汉模式在GetInstance函数中创建对象,那么如果多线程同时调用GetInstance函数时,那么线程不安全。

2.饿汉模式在main函数执行前就已经创建好了对象,就不会同时对单例对对象进行操作,所以线程安全。

相关推荐
阿让啊1 小时前
C语言strtol 函数使用方法
c语言·数据结构·c++·单片机·嵌入式硬件
liulilittle2 小时前
OPENPPP2 —— IP标准校验和算法深度剖析:从原理到SSE2优化实现
网络·c++·网络协议·tcp/ip·算法·ip·通信
TechNomad2 小时前
设计模式:状态模式(State Pattern)
设计模式·状态模式
努力也学不会java2 小时前
【设计模式】 原型模式
java·设计模式·原型模式
TechNomad4 小时前
设计模式:模板方法模式(Template Method Pattern)
设计模式·模板方法模式
honder试试4 小时前
焊接自动化测试平台图像处理分析-模型训练推理
开发语言·python
^Rocky4 小时前
JavaScript性能优化实战
开发语言·javascript·性能优化
田里的水稻4 小时前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
ponnylv4 小时前
深入剖析Spring Boot启动流程
java·开发语言·spring boot·spring
萧邀人5 小时前
第一课、Cocos Creator 3.8 安装与配置
开发语言