如何优化单例模式中懒汉式实现,以减少在高并发场景下的性能损耗?

在单例模式的懒汉式实现中,为减少高并发场景下的性能损耗,可以采用双重检查锁定(Double - Checked Locking)机制,并结合 volatile 关键字来优化。以下是优化后的代码示例:
 
cpp   
#include <iostream>
#include <thread>
#include <mutex>

class Singleton {
public:
    // 获取单例实例的静态方法
    static Singleton* getInstance() {
        // 第一次检查,若实例已存在,直接返回,避免不必要的锁竞争
        if (instance == nullptr) {
            std::lock_guard<std::mutex> guard(mutex);
            // 第二次检查,确保在获取锁后再次确认实例是否已创建
            if (instance == nullptr) {
                instance = new Singleton();
            }
        }
        return instance;
    }

private:
    // 单例实例指针
    static volatile Singleton* instance;
    // 互斥锁,用于保护单例实例的创建过程
    static std::mutex mutex;

    // 私有构造函数,防止外部直接创建对象
    Singleton() {}
};

// 初始化单例实例指针为nullptr
volatile Singleton* Singleton::instance = nullptr;
// 初始化互斥锁
std::mutex Singleton::mutex;

int main() {
    // 创建多个线程来测试单例模式在高并发下的情况
    std::thread t1([]() { Singleton* s1 = Singleton::getInstance(); });
    std::thread t2([]() { Singleton* s2 = Singleton::getInstance(); });

    t1.join();
    t2.join();

    return 0;
}
 
 
在上述代码中, volatile 关键字确保了 instance 变量在多线程环境下的可见性,即当一个线程修改了 instance 的值,其他线程能够立即看到这个变化。双重检查锁定机制则避免了在每次调用 getInstance 方法时都进行加锁操作,只有在第一次创建实例时才会加锁,从而提高了并发性能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

C++ 老炮儿的技术栈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值