单例模式确保类唯一实例,提供全局访问点。①懒汉模式延迟创建,多线程需加锁保证安全;②饿汉模式启动即初始化,线程安全但可能浪费资源;③C++11局部静态变量方式最推荐,兼具线程安全、延迟初始化与简洁性;④应删除拷贝构造与赋值操作防止复制,确保唯一性。

在C++中,单例模式确保一个类只有一个实例,并提供一个全局访问点。实现时需要控制构造函数的访问权限,同时管理对象的生命周期。以下是几种常见的单例模式实现方式。
懒汉模式在第一次使用时才创建实例,适合资源敏感的场景。
基本实现:
class Singleton {
private:
static Singleton* instance;
Singleton() {} // 私有构造函数
<p>public:
static Singleton* getInstance() {
if (instance == nullptr) {
instance = new Singleton();
}
return instance;
}
};</p><p>// 静态成员初始化
Singleton* Singleton::instance = nullptr;</p>注意:这种写法在多线程环境下不安全,多个线程可能同时进入if判断,导致多次创建实例。
立即学习“C++免费学习笔记(深入)”;
线程安全版本可以加锁:
#include <mutex>
<p>class Singleton {
private:
static Singleton* instance;
static std::mutex mtx;
Singleton() {}</p><p>public:
static Singleton* getInstance() {
std::lock_guard<std::mutex> lock(mtx);
if (instance == nullptr) {
instance = new Singleton();
}
return instance;
}
};</p><p>Singleton* Singleton::instance = nullptr;
std::mutex Singleton::mtx;</p>饿汉模式在程序启动时就创建实例,天然线程安全。
class Singleton {
private:
static Singleton instance;
Singleton() {}
<p>public:
static Singleton& getInstance() {
return instance;
}
};</p><p>// 全局初始化,程序运行前完成
Singleton Singleton::instance;</p>优点是简单、线程安全;缺点是无论是否使用都会创建对象,可能浪费资源。
C++11起,局部静态变量的初始化具有线程安全性,这是最简洁且安全的方式。
class Singleton {
private:
Singleton() {}
<p>public:
static Singleton& getInstance() {
static Singleton instance; // 局部静态变量
return instance;
}
};</p>这种方式自动保证线程安全,延迟初始化,代码简洁,是现代C++推荐的单例实现方法。
为防止外部复制或继承破坏单例,应显式删除拷贝构造和赋值操作:
class Singleton {
private:
Singleton() {}
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
<p>public:
static Singleton& getInstance() {
static Singleton instance;
return instance;
}
};</p>这样可避免对象被意外复制,确保唯一性。
基本上就这些。推荐使用局部静态变量方式,简洁、安全、高效。
以上就是c++++中如何创建单例模式_c++单例模式实现方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号