在C++中,可以通過以下幾種方式來實現單例模式:
class Singleton {
private:
static Singleton* instance;
Singleton() {} // 私有構造函數,防止類外實例化對象
public:
static Singleton* getInstance() {
return instance;
}
};
Singleton* Singleton::instance = new Singleton();
在該實現方式中,單例對象在程序啟動時就被創建出來,因此稱為“餓漢式”。在調用getInstance()
方法時,直接返回已創建好的實例。
class Singleton {
private:
static Singleton* instance;
Singleton() {} // 私有構造函數,防止類外實例化對象
public:
static Singleton* getInstance() {
if (instance == nullptr) {
instance = new Singleton();
}
return instance;
}
};
Singleton* Singleton::instance = nullptr;
在該實現方式中,單例對象在第一次調用getInstance()
方法時才被創建出來,因此稱為“懶漢式”。通過判斷instance
是否為nullptr
,來判斷是否已經創建實例,如果是則創建實例,如果不是則直接返回實例。
class Singleton {
private:
static Singleton* instance;
static std::mutex mtx;
Singleton() {} // 私有構造函數,防止類外實例化對象
public:
static Singleton* getInstance() {
if (instance == nullptr) {
std::lock_guard<std::mutex> lock(mtx);
if (instance == nullptr) {
instance = new Singleton();
}
}
return instance;
}
};
Singleton* Singleton::instance = nullptr;
std::mutex Singleton::mtx;
在該實現方式中,通過使用雙重檢查鎖定來保證線程安全。首先判斷instance
是否為nullptr
,如果是則加鎖,再次判斷instance
是否為nullptr
,如果是則創建實例。通過使用std::mutex
來實現線程同步。
以上是幾種常見的單例模式實現方式,具體選擇哪種方式取決于實際需求和場景。