#include <iostream> // std::cout
#include <thread> // std::thread
#include <chrono> // std::chrono::seconds
#include <mutex> // std::mutex, std::unique_lock
#include <condition_variable> // std::condition_variable, std::cv_status
std::mutex mtx;
std::condition_variable cv;
int value;
void do_read_value()
{
std::this_thread::sleep_for(std::chrono::seconds(5));
cv.notify_one();
}
int main()
{
std::cout << "Please, enter an integer (I'll be printing dots): \n";
std::thread th(do_read_value);
std::unique_lock<std::mutex> lck(mtx);
std::cout << "main pid: " << std::this_thread::get_id() << std::endl;
//最后一个参数是预制条件,调用wait_for的时候,首先就会判断这个条件,
//如果这个条件返回false,那么会继续等待,如果再超时之前,收到了一个notify
//那么他会再次执行这个预制条件来进行判断,超时的时候也还会再此执行这个条件,
//这种可以用在处理队列事件
cv.wait_for(lck, std::chrono::seconds(20), [] {
std::cout << "begin cPid:" <<std::this_thread::get_id()<< std::endl;
std::this_thread::sleep_for(std::chrono::seconds(1));
std::cout << "end" << std::endl;
return false;
});
std::cout << "aaaaaaaaa" << std::endl;
std::cout << "You entered: " << value << '\n';
std::this_thread::sleep_for(std::chrono::seconds(100));
//th.join();
return 0;
}
结果输出:
~/tmp$ ./test
Please, enter an integer (I'll be printing dots):
main pid: 140129166624576 //首次进入触发一次{}内容,但不符合20s等待时长条件,进入阻塞。
begin cPid:140129166624576
end
begin cPid:140129166624576 //cv.notify_one()唤醒的主线程的阻塞,又触发一次{}内容,判断还是不
//符合20s等待时长条件,继续阻塞进入等待状态。
end
begin cPid:140129166624576 //最后达到20s等待时长条件,主线程自动唤醒,再次触发一次{}内容,
//跳出阻塞,执行后续内容
end
aaaaaaaaa
You entered: 0
C++ 条件变量之 waite_for
最新推荐文章于 2023-08-17 14:47:16 发布