Using ``spinlock`` in Singleton class

发布于 2022-08-25 12:06:44 字数 1127 浏览 13 评论 0

我写了一个单例类,使用了双重检查锁定的方法,确保只有一个类实例生成。

其中我使用mutex,从而实现锁定方法。

如果我想把mutex换成spinlock,我该怎么写?求一份比较详细的代码。。。

(单纯的替换mutex->spinlock好像会报编译错误。

另外,顺便问下,把mutex换成spinlock在Singleton模式下会有比较大的性能提升么?(目测不会。。。= =。。

我的代码如下:

#ifndef SINGLETON
#define SINGLETON

class CSingleton
{
public:
    static CSingleton* getInstance()
    {
        if(!uniqueInstance)
        {
            pthread_mutex_lock(&mutex);
            if(!uniqueInstance)
            {
                uniqueInstance = new CSingleton();
            }
            pthread_mutex_unlock(&mutex);
        }
        return uniqueInstance;
    }
    void fill(int x){ val += x; }
    int getVal(){ return val; }
private:
    int val;
    CSingleton()
    {
        val = 0;
    }
    CSingleton(const CSingleton&){}
    CSingleton & operator = (const CSingleton&);
    static CSingleton * uniqueInstance;
    static pthread_mutex_t mutex;
};

CSingleton * CSingleton::uniqueInstance = NULL;
pthread_mutex_t CSingleton::mutex = PTHREAD_MUTEX_INITIALIZER;

#endif

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

柠檬色的秋千 2022-09-01 12:06:44

新的 C++11 标准增加了 2 种单例的写法

1 static 变量是线程安全的

T& getInstance ()
{
    static T instance;
    return instance;
}

2 使用 std::call_once,他保证了函数只会调用一次

std::once_flag flag;
T* instance;
T* getInstance ()
{
    std::call_once(flag, [instance]()
    {
        instance = new T;
    });
    return instance;
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文