单例模式通过私有构造函数、静态实例和全局访问方法确保类唯一实例。1. 懒汉模式在多线程下需加锁保证安全,但影响性能;2. 双重检查锁定减少锁竞争;3. C++11推荐使用局部静态变量实现(Meyers单例),线程安全、延迟初始化、自动析构且无需手动管理内存。

在C++中,单例模式确保一个类只有一个实例,并提供一个全局访问点。实现时需要考虑构造函数私有化、静态实例和全局访问方法。同时,在多线程环境下,必须处理线程安全问题。
基本单例结构
单例的核心是控制实例的创建。通过将构造函数设为私有,防止外部直接实例化。提供一个静态成员函数来获取唯一实例。
class Singleton {
public:
立即学习“C++免费学习笔记(深入)”;
static Singleton& getInstance() {
if (instance == nullptr) {
instance = new Singleton();
}
return *instance;
}
private:
Singleton() {}
static Singleton* instance;
};
Singlton* Singleton::instance = nullptr;
懒汉模式与线程安全
上面的实现是“懒汉模式”,即第一次调用时才创建实例。但在多线程下,多个线程可能同时判断instance == nullptr,导致重复创建。
解决办法是加锁:
#include
class Singleton {
public:
立即学习“C++免费学习笔记(深入)”;
static Singleton& getInstance() {
std::lock_guard lock(mutex_);
if (instance == nullptr) {
instance = new Singleton();
}
return *instance;
}
private:
Singleton() {}
static Singleton* instance;
static std::mutex mutex_;
};
虽然线程安全,但每次调用都加锁影响性能。
双重检查锁定(Double-Checked Locking)
优化方式是在加锁前再检查一次,减少锁竞争:
static Singleton& getInstance() {
if (instance == nullptr) {
std::lock_guard lock(mutex_);
if (instance == nullptr) {
instance = new Singleton();
}
}
return *instance;
}
注意:使用原始指针需手动管理内存,建议配合智能指针或静态对象。
C++11后的推荐写法:局部静态变量
C++11标准保证局部静态变量的初始化是线程安全的,且只执行一次。这是最简洁且安全的方式:
class Singleton {
public:
立即学习“C++免费学习笔记(深入)”;
static Singleton& getInstance() {
static Singleton instance;
return instance;
}
private:
Singleton() {}
~Singleton() {}
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
};
这种实现称为Meyers单例,无需显式加锁,延迟初始化,自动析构,线程安全。
基本上就这些。优先使用局部静态变量方式,简单可靠。避免手动new/delete,防止内存泄漏。禁用拷贝构造和赋值操作,确保唯一性。
以上就是c++++中如何实现一个单例模式_单例模式的实现方法与线程安全问题的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1484545.html
微信扫一扫
支付宝扫一扫