std::condition_variable 是条件变量,当?std::condition_variable 对象的某个wait ?函数被调用的时候,它使用?std::unique_lock (通过?std::mutex ) 来锁住当前线程。当前线程会一直被阻塞,直到另外一个线程在相同的?std::condition_variable ?对象上调用了?notification ?函数来唤醒当前线程。
#include <thread>
#include <iostream>
#include <mutex>
#include <condition_variable>
std::mutex data_mutex;
std::condition_variable data_var;
int flag=1;
int i=0;
#define MAXNUM 100
void printA(){
while(i<MAXNUM){
// std::this_thread::sleep_for(std::chrono::seconds(1)); //打印节奏变慢
std::unique_lock<std::mutex> lck(data_mutex);
//当flag为1时,wait不阻塞;否则wait阻塞当前线程。
//允许其他锁住的线程继续,当其他线程调用notify函数后,并且flag为1时
//此线程被唤醒
data_var.wait(lck, []{return flag==1;});
flag=2;
if(i >= 100){
data_var.notify_all();
break;
}
i++;
std::cout<<"threadA:"<<i<<std::endl;
data_var.notify_all();
}
std::cout<<"finish A"<<std::endl;
}
void printB(){
while(i<MAXNUM){
std::unique_lock<std::mutex> lck(data_mutex);
//当flag为2时,wait不阻塞;否则wait阻塞当前线程。
//允许其他锁住的线程继续,当其他线程调用notify函数后,并且flag为2时
//此线程被唤醒
data_var.wait(lck, []{return flag==2;});
flag = 3;
if(i >= 100){
data_var.notify_all();
break;
}
i++;
std::cout<<"threadB:"<<i<<std::endl;
data_var.notify_all();
}
std::cout<<"finish B"<<std::endl;
}
void printC(){
while(i<MAXNUM){
std::unique_lock<std::mutex> lck(data_mutex);
//当flag为3时,wait不阻塞;否则wait阻塞当前线程。
//允许其他锁住的线程继续,当其他线程调用notify函数后,并且flag为3时
//此线程被唤醒
data_var.wait(lck, []{return flag==3;});
flag = 1;
if(i >= 100){
data_var.notify_all();
break;
}
i++;
std::cout<<"threadC:"<<i<<std::endl;
data_var.notify_all();
}
std::cout<<"finish C"<<std::endl;
}
int main(){
std::thread tA(printA);
std::thread tB(printB);
std::thread tC(printC);
tA.join();
tB.join();
tC.join();
std::cout << i << std::endl;//最后验证i是否严格等于100
system("pause");
return 0;
}
打印结果:
...前面的93个打印行省略不写了
threadA:94
threadB:95
threadC:96
threadA:97
threadB:98
threadC:99
threadA:100
finish A
finish C
finish B
100
请按任意键继续. . .
|