C++代码 单例模式
时间: 2023-09-28 16:11:11 浏览: 57
在C++中,实现单例模式可以使用以下方法:
```cpp
class Singleton {
private:
static Singleton* instance;
Singleton() {} // 私有构造函数,防止实例化
public:
static Singleton* getInstance() {
if (instance == nullptr) {
instance = new Singleton();
}
return instance;
}
};
// 初始化静态成员变量
Singleton* Singleton::instance = nullptr;
```
在上述示例中,`Singleton` 类只能通过 `getInstance()` 方法获取唯一的实例。构造函数被声明为私有,防止外部直接实例化该类。`getInstance()` 方法会首先检查实例是否已经存在,如果不存在则创建一个新实例并返回,如果已经存在则直接返回现有实例。
使用示例:
```cpp
Singleton* singleton = Singleton::getInstance();
```
这样就可以获取到唯一的 `Singleton` 实例。
值得注意的是,上述代码只提供了基本的单例模式实现,对于多线程环境下的安全性还需要额外的处理。可以使用互斥锁或者双重检查锁定等机制来保证线程安全。
相关问题
c++ 单例模式代码
以下是 C++ 实现单例模式的代码:
```cpp
class Singleton {
private:
static Singleton* instance; // 声明静态指针变量
// 私有构造函数和析构函数
Singleton() {}
~Singleton() {}
public:
static Singleton* getInstance() { // 获取实例的静态方法
if (instance == nullptr) {
instance = new Singleton(); // 如果实例不存在,则创建实例
}
return instance;
}
void doSomething() { // 单例类的成员函数
// ...
}
};
// 初始化静态指针变量
Singleton* Singleton::instance = nullptr;
```
在使用时,可以通过调用 `Singleton::getInstance()` 方法来获取单例实例,然后通过实例调用成员函数 `doSomething()` 进行操作。
c++单例模式伪代码
以下是C++单例模式的伪代码:
```cpp
template<typename T>
class Singleton {
public:
static T& getInstance() {
if (!value_) {
MutexGuard guard(mutex_);
if (!value_) {
value_ = new T();
}
}
return *value_;
}
private:
Singleton();
~Singleton();
static T* value_;
static Mutex mutex_;
};
template<typename T>
T* Singleton<T>::value_ = NULL;
template<typename T>
Mutex Singleton<T>::mutex_;
```
其中,`Mutex`是一个互斥锁类,`MutexGuard`是一个互斥锁保护类,用于自动加锁和解锁。`getInstance()`方法用于获取单例对象的引用,如果单例对象还未创建,则加锁创建,否则直接返回已创建的单例对象。`value_`是单例对象的指针,`mutex_`是互斥锁对象。