c++如何实现一个单例模式_c++设计模式之单例模式实现方法

19次阅读

单例模式确保一个类仅有一个实例并提供全局访问点。c++中常见实现包括:懒汉式(线程 不安全,延迟创建但 多线程 下可能重复实例化);加锁的懒汉式(线程安全但性能开销大);双重检查锁定(减少锁开销,需注意内存模型和原子性);局部静态变量(C++11 起线程安全、简洁、自动管理内存,推荐方式)。选择依据为线程安全需求、延迟加载 要求及编译器支持,现代 C ++ 首选局部静态变量实现。

c++ 如何实现一个单例模式_c++ 设计模式之单例模式实现方法

单例模式确保一个类只有一个实例,并提供一个全局访问点。在 C ++ 中,实现单例模式需要控制 构造函数 的访问权限,同时管理实例的生命周期。以下是几种常见的实现方式,各有优缺点,适用于不同场景。

懒汉式(线程不安全)

这种实现方式在第一次调用时才创建实例,节省资源,但多线程环境下可能产生多个实例。

class Singleton {
private:
    Static Singleton* instance;
    Singleton() {}

public:
    static Singleton* getInstance() {
        if (instance == nullptr) {
            instance = new Singleton();
        }
        return instance;
    }
};
Singleton* Singleton::instance = nullptr;

问题在于:如果多个线程同时调用 getInstance 且此时 instance 为空,可能多次创建 对象

加锁的懒汉式(线程安全)

通过互斥锁保证线程安全,避免重复创建。

立即学习C++ 免费学习笔记(深入)”;

#include <mutex>

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

public:
    static Singleton* getInstance() {
        std::lock_guard<std::mutex> lock(mtx);
        if (instance == nullptr) {
            instance = new Singleton();
        }
        return instance;
    }
};
Singleton* Singleton::instance = nullptr;
std::mutex Singleton::mtx;

虽然线程安全,但每次调用都加锁影响性能。可以结合双重检查锁定优化。

双重检查锁定(推荐用于动态分配)

减少锁的开销,只在必要时加锁。

c++ 如何实现一个单例模式_c++ 设计模式之单例模式实现方法

AIBox 一站式 AI 创作平台

AIBox365 一站式 AI 创作平台,支持 ChatGPT、GPT4、Claue3、Gemini、Midjourney 等国内外大模型

c++ 如何实现一个单例模式_c++ 设计模式之单例模式实现方法 31

查看详情 c++ 如何实现一个单例模式_c++ 设计模式之单例模式实现方法

static Singleton* getInstance() {
    if (instance == nullptr) {
        std::lock_guard<std::mutex> lock(mtx);
        if (instance == nullptr) {
            instance = new Singleton();
        }
    }
    return instance;
}

注意:需确保 instance 的写入是原子的,C++11 以后的内存模型支持这一点。否则可能因指令重排导致问题。

局部静态变量(最简洁且线程安全)

C++11 起,局部静态变量的初始化是线程安全的,这是最推荐的方式。

class Singleton {
private:
    Singleton() {}

public:
    static Singleton& getInstance() {
        static Singleton instance;
        return instance;
    }
};

优点:代码简洁,自动释放,线程安全,延迟初始化。无需手动管理内存。

如果需要显式控制析构顺序或自定义销毁逻辑,可配合智能 指针 或注册 atexit 函数。

基本上就这些。选择哪种方式取决于是否需要 延迟加载、线程安全要求以及编译器支持情况。现代 C ++ 推荐使用局部静态变量方式,简单可靠。

站长
版权声明:本站原创文章,由 站长 2025-11-11发表,共计1772字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
1a44ec70fbfb7ca70432d56d3e5ef742
text=ZqhQzanResources