单例模式确保类唯一实例并提供全局访问点。C++中常用懒汉式(线程安全双重检查)、饿汉式(程序启动初始化)和局部静态变量法(C++11推荐,自动线程安全、延迟加载)。适用于日志器、配置管理、数据库连接池等场景,现代C++首选局部静态变量实现。

单例模式是一种常用的设计模式,确保一个类只有一个实例,并提供一个全局访问点。在C++中,实现单例模式需要控制构造函数的访问权限、禁止拷贝和赋值操作,并保证线程安全。下面介绍几种常见的C++单例模式实现方式及其应用场景。
懒汉式单例(延迟初始化)
懒汉式在第一次使用时才创建实例,节省资源。但需注意多线程环境下的安全性。
// 线程安全的懒汉式单例
class Singleton {
private:
static Singleton* instance;
static std::mutex mtx;
// 私有构造函数
Singleton() = default;
// 禁止拷贝和赋值
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
public:
static Singleton* getInstance() {
if (instance == nullptr) {
std::lock_guard lock(mtx);
if (instance == nullptr) {
instance = new Singleton();
}
}
return instance;
}
};
// 静态成员定义
Singleton* Singleton::instance = nullptr;
std::mutex Singleton::mtx;
这种方式使用双重检查锁定(Double-Checked Locking)减少锁竞争,适合多线程环境。
饿汉式单例(程序启动时初始化)
饿汉式在程序启动时就创建实例,天然线程安全,适用于对象创建开销小或必须提前初始化的场景。
立即学习“C++免费学习笔记(深入)”;
class Singleton {
private:
static Singleton instance;
Singleton() = default;
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
public:
static Singleton& getInstance() {
return instance;
}
};
// 全局静态实例
Singleton Singleton::instance;
由于静态变量在程序加载时初始化,无需加锁,性能更好,但可能浪费资源。
局部静态变量法(推荐写法)
C++11起,局部静态变量的初始化是线程安全的,代码简洁且高效。
class Singleton {
private:
Singleton() = default;
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
public:
static Singleton& getInstance() {
static Singleton instance;
return instance;
}
};
这是最推荐的方式:自动线程安全、延迟初始化、无需手动管理内存,析构也由系统完成。
单例模式的应用场景
单例常用于以下情况:
日志记录器:整个系统共用一个日志对象配置管理器:统一读取和保存配置信息数据库连接池:避免频繁创建连接硬件接口访问:如打印机、串口设备等资源有限的场景
使用单例能避免资源冲突,减少内存开销,提高访问效率。
基本上就这些。选择哪种实现方式取决于是否需要延迟加载、线程安全要求以及C++标准支持程度。现代C++推荐使用局部静态变量法,简洁又可靠。
以上就是c++++怎么实现单例模式_c++单例模式实现与应用解析的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1479160.html
微信扫一扫
支付宝扫一扫