一简介
对原子变量的操作是原子操作,能保证在任何情况下都不被打断,是线程安全的,不需要加锁。
在新标准C++11,引入了原子操作的概念,并通过这个新的头文件提供了多种原子操作数据类型,例如,atomic_bool,atomic_int等等,如果我们在多个线程中对这些类型的共享资源进行操作,编译器将保证这些操作都是原子性的,也就是说,确保任意时刻只有一个线程对这个资源进行访问,编译器将保证,多个线程访问这个共享资源的正确性。从而避免了锁的使用,提高了效率。
二 例子
1 原本需要加锁的临界区现在不需要加锁
#include <iostream>
#include <thread>
#include <atomic>
using namespace std;
int main()
{
vector<thread> vec;
atomic<int> num(0);
for (int i = 0; i < 5; i++)
{
vec.emplace_back( [&num]{
for (int i = 0; i < 1000; i++)
{
num += 1;
num.store(10);
}
});
}
for (int i = 0; i < 5; i++)
{
vec[i].join();
}
cout << "num == " << num << endl;
return 0;
}
2 类似信号量
#include <iostream>
#include <thread>
std::atomic< bool > ready(false);
void showNum()
{
this_thread::sleep_for(chrono::seconds(10));
//通过sleep_for来使线程睡眠一定的时间
std::cout << "showNum" << std::endl;
ready = true;
}
void numPlus()
{
std::cout << "wait numPlus" << std::endl;
while (!ready) { std::this_thread::yield(); } // 等待 ready 变为 true
std::cout << "numPlus" << std::endl;
}
int main()
{
thread thShow(showNum);
thread thPlus(numPlus);
thShow.join();
thPlus.join();
return 0;
}
对于少量代码,用原子变量代替锁,效率更高