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
相关推荐
云泽8082 小时前
C++ List 容器详解:迭代器失效、排序与高效操作
开发语言·c++·list
xlq223222 小时前
15.list(上)
数据结构·c++·list
Elias不吃糖2 小时前
总结我的小项目里现在用到的Redis
c++·redis·学习
AA陈超3 小时前
使用UnrealEngine引擎,实现鼠标点击移动
c++·笔记·学习·ue5·虚幻引擎
No0d1es4 小时前
电子学会青少年软件编程(C/C++)六级等级考试真题试卷(2025年9月)
c语言·c++·算法·青少年编程·图形化编程·六级
不会c嘎嘎4 小时前
每日一练 -- day1
c++·算法
yy_xzz4 小时前
VCPKG && Tesseract OCR
c++·图像处理·opencv
hansang_IR5 小时前
【记录】网络流最小割建模三题
c++·算法·网络流·最小割
玖笙&5 小时前
✨WPF编程进阶【7.3】集成动画(附源码)
c++·c#·wpf·visual studio
Dream it possible!5 小时前
LeetCode 面试经典 150_二叉树层次遍历_二叉树的层序遍历(83_102_C++_中等)
c++·leetcode·面试·二叉树