c++怎么实现单例模式_c++设计模式之Singleton实现方法【源码】

admin 百科 11
单例模式确保类仅有一个实例并提供全局访问点;C++中推荐使用C++11局部静态变量实现,因其线程安全、自动内存管理且代码简洁;其他变体如双检锁、饿汉式等按需选用。

c++怎么实现单例模式_c++设计模式之Singleton实现方法【源码】-第1张图片-佛山资讯网

单例模式的核心是:确保一个类只有一个实例,并提供全局访问点。C++ 实现时关键在控制构造、拷贝、赋值,以及线程安全和初始化时机。

基础线程不安全版本(懒汉式)

适用于单线程或明确无并发场景,简单直观:

class Singleton {
private:
    static Singleton* instance;
    Singleton() = default;                    // 私有构造
    Singleton(const Singleton&) = delete;     // 禁用拷贝
    Singleton& operator=(const Singleton&) = delete; // 禁用赋值
<p>public:
static Singleton* getInstance() {
if (instance == nullptr) {
instance = new Singleton();
}
return instance;
}
};</p><p>// 静态成员定义
Singleton* Singleton::instance = nullptr;

登录后复制

C++11 起推荐:局部静态变量(最简洁 & 线程安全)

利用 C++11 标准保证的“函数内局部静态变量初始化的线程安全性”,无需锁、无需手动管理内存:

class Singleton {
private:
    Singleton() = default;
    Singleton(const Singleton&) = delete;
    Singleton& operator=(const Singleton&) = delete;
<p>public:
static Singleton& getInstance() {
static Singleton instance;  // 延迟初始化 + 线程安全
return instance;
}
};

登录后复制

✅ 优点:自动生命周期管理(程序结束时析构)、无内存泄漏、无锁开销、代码极简。
⚠️ 注意:析构顺序不可控,若单例依赖其他静态对象,可能引发未定义行为。

需要显式控制析构?用 std::unique_ptr + double-checked locking(较重但可控)

适用于需在特定时机释放资源、或必须兼容老标准(如 C++03)的场景:

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

标签: c++ 延迟加载 无锁

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~