亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

C++單例類如何實現多線程安全

c++
小樊
91
2024-07-25 17:14:15
欄目: 編程語言

在C++中實現多線程安全的單例類通常使用雙檢鎖機制(Double-Checked Locking Pattern)來確保只有一個實例被創建。下面是一個使用雙檢鎖機制實現多線程安全的單例類的示例代碼:

#include <iostream>
#include <mutex>

class Singleton {
public:
    static Singleton* getInstance() {
        if (instance == nullptr) {
            std::lock_guard<std::mutex> lock(mutex);
            if (instance == nullptr) {
                instance = new Singleton();
            }
        }
        return instance;
    }

private:
    Singleton() {}
    Singleton(const Singleton&) = delete;
    Singleton& operator=(const Singleton&) = delete;

    static Singleton* instance;
    static std::mutex mutex;
};

Singleton* Singleton::instance = nullptr;
std::mutex Singleton::mutex;

int main() {
    Singleton* singleton1 = Singleton::getInstance();
    Singleton* singleton2 = Singleton::getInstance();

    std::cout << "singleton1 address: " << singleton1 << std::endl;
    std::cout << "singleton2 address: " << singleton2 << std::endl;

    return 0;
}

在上面的示例中,getInstance函數使用雙檢鎖機制,在第一次調用時檢查instance是否為nullptr,如果是,則使用std::lock_guard<std::mutex>mutex進行加鎖,然后再次檢查instance是否為nullptr,如果是,則創建一個新的Singleton實例。這樣可以確保在多線程環境下只有一個實例被創建。

需要注意的是,C++11及以上的標準庫中提供了std::call_oncestd::once_flag可以更方便地實現單例模式,可以參考這篇文章:C++11單例模式的線程安全實現

0
巴塘县| 黄冈市| 伊吾县| 延安市| 石狮市| 青河县| 土默特左旗| 岳普湖县| 资中县| 射阳县| 镇宁| 桦川县| 昆明市| 偏关县| 桃源县| 大庆市| 瑞安市| 兰坪| 新巴尔虎右旗| 合水县| 顺义区| 临夏市| 阿克陶县| 甘肃省| 巫山县| 奉节县| 玉门市| 汕尾市| 郎溪县| 台北市| 来宾市| 额尔古纳市| 逊克县| 田东县| 民和| 涞水县| 临潭县| 连云港市| 永善县| 长葛市| 莲花县|