多线程和模板化单例竞争条件

Posted

技术标签:

【中文标题】多线程和模板化单例竞争条件【英文标题】:Multi Threaded and templated singleton race condition 【发布时间】:2017-05-04 09:18:12 【问题描述】:

我正在尝试创建一个多线程和模板化的单例,作为我高级 C++ 学习的一部分。有人告诉我,我的代码中有竞态条件,经过数小时的尝试后我找不到它。

我不会写整个课程(虽然它是一个简单的课程),而是我一直关注的确切位置:

template <class T>
void Singleton<T>::onceFunction()

    static T instanceObject; 
    Singleton<T>::instance = &instanceObject;


template <class T>
T& Singleton<T>::getInstance()

    while (0 == Singleton::instance)
    
        static pthread_once_t  once_control = PTHREAD_ONCE_INIT;
        pthread_once(&once_control, Singleton<T>::onceFunction);  
    
    return *Singleton::instance;

我正在使用 pthread_once(),因为我没有使用 c++11 进行编译。

【问题讨论】:

您可能会发现这很有用:*** once_control 何时初始化 -- 以及在哪个线程上? 【参考方案1】:

您显示的代码旨在保护/序列化的初始化

static T instanceObject;

Singleton&lt;T&gt;::onceFunction() 中所定义。为了实现这一点,您使用pthread_once。但是,您已经在函数/块范围内使用静态存储声明了 pthread_once_t 标志 once_control...

static pthread_once_t  once_control = PTHREAD_ONCE_INIT;

因此,我认为 once_control 的初始化与您的代码旨在解决 instanceObject 的竞争条件相同。

改为将once_control 设为Singleton&lt;T&gt; 的静态成员。

注意:您的代码还假定分配...

Singleton<T>::instance = &instanceObject;

是原子的。

【讨论】:

以上是关于多线程和模板化单例竞争条件的主要内容,如果未能解决你的问题,请参考以下文章

基于多线程任务队列执行时间测试——泛型单例模式落地

如何使此 Java 代码正常运行? [多线程,竞争条件]

Java代码竞争条件多线程?

多线程系列Race Condition的产生和解决

Java多线程中的竞争条件锁以及同步的概念

核心数据 - 多线程 - 启动时的竞争条件