C++的单例模式

忘记之前有没有写过单例模式了。

再记录一下:

我使用的代码:

cpp 复制代码
#ifndef SINGLETON_MACRO_HPP
#define SINGLETON_MACRO_HPP

#define SINGLETON_DECL(class_name) \
public: \
    static class_name& instance() { \
        static class_name s_instance; \
        return s_instance; \
    } \
private: \
    class_name();\
    class_name(const class_name&) = delete; \
    class_name& operator=(const class_name&) = delete;

#endif // SINGLETON_MACRO_HPP

双锁单例:

cpp 复制代码
#include <iostream>
#include <mutex>

class Singleton {
private:
    static Singleton* instance;
    static std::mutex mtx;

    // 私有化构造函数,确保不能在类外部进行实例化
    Singleton() {}

public:
    // 删除复制构造函数和复制赋值操作符
    Singleton(const Singleton& other) = delete;
    Singleton& operator=(const Singleton& other) = delete;

    static Singleton* getInstance() {
        if (instance == nullptr) { // 判断实例是否已经被创建,提高效率
            std::lock_guard<std::mutex> lock(mtx); // 锁定
            if (instance == nullptr) { // 再次检查,以确保线程安全
                instance = new Singleton();
            }
        }
        return instance;
    }
};

// 初始化静态成员
Singleton* Singleton::instance = nullptr;
std::mutex Singleton::mtx;

int main() {
    Singleton* s1 = Singleton::getInstance();
    Singleton* s2 = Singleton::getInstance();

    if (s1 == s2) {
        std::cout << "Both instances are identical." << std::endl;
    } else {
        std::cout << "Instances are different." << std::endl;
    }

    return 0;
}

单例模式的不同实现方式各有优缺点

双检锁(Double Checked Locking):

优点:

线程安全。

在实例已经被创建之后,直接返回实例,避免了每次获取实例时都需要获取锁的开销。

缺点:

代码相对复杂。

在某些老的编译器或硬件架构上,双检锁可能无法正常工作,可能需要内存屏障或其他同步机制。

静态局部变量(Meyers' Singleton):
cpp 复制代码
class Singleton {
public:
    static Singleton& getInstance() {
        static Singleton instance;
        return instance;
    }
private:
    Singleton() {}
};

优点:

线程安全(在 C++11 及以后的版本中)。

代码简单、清晰。

延迟初始化:只有在首次调用 getInstance 时,实例才会被创建。

缺点:

对于老的 C++ 标准(C++11 之前),这种方法可能不是线程安全的。

饿汉式:
cpp 复制代码
class Singleton {
private:
    static Singleton instance;
    Singleton() {}
public:
    static Singleton& getInstance() {
        return instance;
    }
};

优点:

线程安全,因为实例在程序开始时就已经被初始化。

代码简单。

缺点:

实例在程序开始时就被创建,即使它从未被使用,可能会导致不必要的资源占用或初始化开销。

懒汉式(简单):
cpp 复制代码
class Singleton {
private:
    static Singleton* instance;
    Singleton() {}
public:
    static Singleton* getInstance() {
        if (!instance) {
            instance = new Singleton();
        }
        return instance;
    }
};

优点:

实现简单。

延迟初始化,只在首次获取实例时创建。

缺点:

非线程安全。如果多个线程同时尝试创建实例,可能导致多个实例被创建。

在实际的使用场景中,要根据具体的需求和上下文来选择合适的实现方法。例如,如果线程安全性很重要,那么使用双检锁或C++11及以后版本的静态局部变量方法可能更合适。

最后问题:我用的是什么模式??

相关推荐
知然6 小时前
鸿蒙 Native API 的封装库 h2lib_arkbinder
c++·arkts·鸿蒙
十五年专注C++开发6 小时前
Qt .pro配置gcc相关命令(三):-W1、-L、-rpath和-rpath-link
linux·运维·c++·qt·cmake·跨平台编译
Cai junhao7 小时前
【Qt】Qt控件
开发语言·c++·笔记·qt
uyeonashi7 小时前
【QT系统相关】QT网络
开发语言·网络·c++·qt
我命由我123458 小时前
嵌入式 STM32 开发问题:烧录 STM32CubeMX 创建的 Keil 程序没有反应
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·嵌入式
筏.k9 小时前
C++: 类 Class 的基础用法
android·java·c++
C++ 老炮儿的技术栈9 小时前
手动实现strcpy
c语言·开发语言·c++·算法·visual studio
一条叫做nemo的鱼9 小时前
从汇编的角度揭开C++ this指针的神秘面纱(下)
java·汇编·c++·函数调用·参数传递
ComputerInBook10 小时前
理解 C++ 的 this 指针
开发语言·c++·指针·this·this指针
MikeWe10 小时前
一文读懂C++移动语义和完美转发
c++