C++设计模式-单例

一.概念

属于创建型模式 ,用于创建只能产生一个实例对象(即类对象)的类 ,同时提供能够访问该类对象的方法,一般通过getInstance(),即类的静态成员函数

二.分类

包含两种模式,分别为:饿汉模式和懒汉模式

1.饿汉模式

提前创建类对象,并保存在静态成员变量。该模式中类对象即使未使用,也会提前创建,该模式较简单,但是可能会造成资源浪费。

2.懒汉模式

首次调用geInstance()静态成员函数 时,才会创建单例对象(即类对象)

懒汉模式可以避免资源浪费,但是要防止多线程 同时调用getInstance()静态成员函数,造成创建多个单例对象。可通过加锁的方式,防止多线程下资源冲突。

三.代码实现

1.饿汉模式

cpp 复制代码
//Singleton.h
//单例模式-饿汉模式
#ifndef SINGLETON_H
#define SINGLETON_H

class Singleton {
private:
    Singleton();
    ~Singleton();

    static Singleton* m_instance;

public:
    static Singleton* getInstance();
};
#endif 
cpp 复制代码
//Singleton.cpp
#include "Singleton.h"
//类加载时 创建单例对象
Singleton* Singleton::m_instance = new Singleton();
Singleton::Singleton() {}
Singleton::~Singleton() {}

Singleton* Singleton::getInstance()
{
    return m_instance;
}

2.懒汉模式

cpp 复制代码
//SingletonLH.h
// 单例模式-懒汉模式
#ifndef SINGLETONLH_H
#define SINGLETONLH_H

class SingletonLH {
private:
    SingletonLH();
    ~SingletonLH();
    static SingletonLH* m_instance;
public:
    static SingletonLH* getInstance();
};
#endif 
cpp 复制代码
//SingletonLH.cpp
#include "SingletonLH.h"

SingletonLH *SingletonLH::m_instance = nullptr;

SingletonLH::SingletonLH() {}
SingletonLH::~SingletonLH() {}

//懒汉式:首次调用时创建单例对象 避免资源浪费
SingletonLH *SingletonLH::getInstance()
{
    if(m_instance == nullptr)
    {
        m_instance = new SingletonLH();
    }
    return m_instance;
}

3.懒汉模式-多线程加锁

cpp 复制代码
//SingletonLock.h
// 懒汉模式-多线程加锁
#ifndef SINGLETONLOCK_H
#define SINGLETONLOCK_H
#include <mutex>

class SingletonLock {
private:
    SingletonLock();
    ~SingletonLock();
    static SingletonLock *m_instance;
    //互斥锁
    static std::mutex m_mutex;
public:
    static SingletonLock *getInstance();
};
#endif 
cpp 复制代码
//SingletonLock.cpp
#include "SingletonLock.h"

SingletonLock *SingletonLock::m_instance = nullptr;
std::mutex SingletonLock::m_mutex;

SingletonLock::SingletonLock() {}
SingletonLock::~SingletonLock() {}

SingletonLock *SingletonLock::getInstance()
{
    //确保多线程操作时,只有一个线程执行创建实例
    std::lock_guard<std::mutex> lock(m_mutex);//构造时自动加锁  析构时自动解锁
    if(m_instance == nullptr)
    {
        m_instance = new SingletonLock();
    }
    return  m_instance;
}

4.main.cpp

cpp 复制代码
#include <iostream>
#include "Singleton.h"
#include "SingletonLH.h"
#include "SingletonLock.h"
using namespace std;
int main() 
{
    cout << "饿汉模式:" << Singleton::getInstance() << endl;
    cout << "懒汉模式:" << SingletonLH::getInstance() << endl;
    cout << "懒汉-多线程模式:" << SingletonLock::getInstance() << endl;
    return 0;
}

5.运行结果

cpp 复制代码
饿汉模式:0x1086750
懒汉模式:0x662ca0
懒汉-多线程模式:0x662ce0
相关推荐
咖啡八杯1 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
槑有老呆1 天前
从 Prompt Engineering 到 Harness Engineering:AI 编程的下一次跃迁
设计模式
HjhIron2 天前
从Prompt到Context:大模型应用开发的范式转移
设计模式·aigc·ai编程
郝学胜_神的一滴3 天前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
咖啡八杯3 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
见过夏天3 天前
C++ 基础入门完全指南
c++
胡萝卜术4 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
亦暖筑序4 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户805533698035 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt