C++中单实例模式的一个简单的写法是:将对象定义为一个函数的局部静态变量,然后返回对象的引用,这样在函数首次调用时完成静态对象的初始化,但这一做法在C++11前并不是线程安全的,而C++11已经可以保证其线程安全性:
在当前线程执行到需要初始化静态变量时,如果有其他线程正在初始化该变量,则阻塞当前线程,直到初始化完成为止。
#include <iostream>
#include <thread>
using namespace std;
class A{
public:
A(int t)
{
cout<<"constructor A, thread:"<<t<<endl;
}
};
A& getSignleA(int t)
{
static A s_a(t); //函数首次被调用时,初始化本地静态变量s_a
return s_a;
}
void tFunc(int i)
{
getSignleA(i); //每个线程都调用getSignleA,但只有第一个调动次函数的线程能初始化静态变量s_a
cout<<"thread "<<i<<endl;
}
int main ()
{
thread t[10]; //创建十个线程,每个线程都会通过tFunc调用getSignleA
for(int i=0; i<10; ++i)
{
t[i] = thread(tFunc, i);
}
for(int i=0; i<10; ++i)
{
t[i].join();
}
return 0;
}
运
C++11引入了对局部静态变量的线程安全保证,确保在多线程环境中,当多个线程同时首次访问一个函数内的局部静态变量时,会进行线程同步,只允许一个线程进行初始化,其他线程等待初始化完成后再继续执行。
订阅专栏 解锁全文
1073

被折叠的 条评论
为什么被折叠?



