单例模式通过局部静态变量实现线程安全,C++11保证其初始化唯一性,推荐使用Meyers' Singleton方式,简洁且自动管理生命周期。

单例模式确保一个类只有一个实例,并提供全局访问点。在C++中实现线程安全的单例模式,推荐使用“局部静态变量 + 函数内定义”的方式,这是最简洁且线程安全的做法。
1. C++11 起的线程安全单例(推荐写法)
C++11 标准规定:函数内的局部静态变量初始化是线程安全的,多个线程同时调用该函数时,只会初始化一次。利用这一特性可以轻松写出线程安全的单例。
class Singleton { private: Singleton() = default; // 禁止外部构造 ~Singleton() = default; // 析构函数私有化 Singleton(const Singleton&) = delete; // 禁止拷贝 Singleton& operator=(const Singleton&) = delete; // 禁止赋值 public: static Singleton& getInstance() { static Singleton instance; // 局部静态变量,C++11 线程安全 return instance; } };使用方式:
Singleton& s1 = Singleton::getInstance(); Singleton& s2 = Singleton::getInstance(); // s1 和 s2 是同一个对象2. 手动加锁的双检锁模式(传统写法,不推荐除非旧编译器)
在C++11之前,常用双检锁(Double-Checked Locking)配合互斥锁实现线程安全。但现在已有更优解,仅作了解。
立即学习“C++免费学习笔记(深入)”;
#include这种写法复杂且容易出错,比如内存重排序问题(需用内存屏障),不如局部静态变量简洁可靠。
3. 注意事项与建议
- 优先使用局部静态变量方式(Meyers' Singleton),代码少、线程安全、自动释放。
- 避免使用动态分配 + 手动管理生命周期的方式,容易引发内存泄漏或析构顺序问题。
- 如果需要延迟初始化且控制析构行为,可结合智能指针和静态变量。
- 注意单例的析构时机不可控,不要在析构函数中依赖其他全局/静态对象。











