c++11中static类对象构造函数线程安全

在c++11中,static静态类对象在执行构造函数进行初始化的过程是线程安全的,有了这个特征,我们可以自己动手轻松的实现单例类,下面给出一个验证例子:

1.清单1:staticSafe.h

#include
#include
using namespace std;
class Cnum
{
public:
Cnum()
{
std::cout << “construct start” << std::endl;
std::this_thread::sleep_for(std::chrono::seconds(5)); //构造函数中休眠5s
num++;
std::cout << “construct stop” << std::endl;
}
void Test()
{
std::cout << “id:” << std::this_thread::get_id()<<",num="<< num<<std::endl;
std::this_thread::sleep_for(std::chrono::seconds(1));
}
static int num;
};

  1. 清单2:main.cpp

int Cnum::num = 0; //初始化静态成员
void func(void* argv)
{
int i = *(int *)argv;
std::cout <<i<< std::endl; //每个线程启动时,打印线程次序号
static Cnum a; //内部静态成员变量的初始化时线程安全的,只有一个线程能执行初始化,其他线程会在此阻塞
a.Test();
}
void main()
{
for (int i = 0; i < 10; i++) //开启10个线程,模拟并发访问情形
{
std::thread t1(func, (void *)&i);
t1.detach();
}
system("pause ");//暂停一下
}

  1. 运行结果

在这里插入图片描述
从结果中可以看出:1)当打印“construct stop” 以后,其他线程才陆续执行Test函数 2) 所有线程打印的num为1。以上现象表明:当有一个线程执行static类对象的构造函数时,其他欲访问该static类对象的线程都是阻塞的。

发布了302 篇原创文章 · 获赞 5 · 访问量 7014
展开阅读全文
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术黑板 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览