#include <iostream>
using namespace std;
int main()
{
// 一: 条件变量 std::condition_variable wait() notify_one()
// 线程A:等待一个条件满足
// 线程B:专门往消息队列中push数据,通知线程A
// std::condition_variable实际上是一个类,是一个和条件相关的类,说白了就是等待一个条件达成
// 这个类是需要和互斥量来配合工作的,用的时候我们要生成这个类的对象;
std::condition_variable my_cond;
while (true)
{
{
// std::unique_lock<std::mutex> lock(xxx_mutex);
// wait()用来等一个东西
// 如果第二个参数lambda表达式返回值是true,那么wait()直接返回;
// 如果第二个参数lambda表达式返回值是false,那么wait()将解锁互斥量,并阻塞到本行,
// 那阻塞到什么时候为止?阻塞到其它某个线程调用notify_one()或notify_all()成员函数为止;
// 如果wait()没有第二个参数:my_cond.wait(lock);那么就跟第二个参数lambda表达式返回false效果一样
// wait()将解锁互斥量,并阻塞到本行,阻塞到其它某个线程调用notify_one()或notify_all()成员函数为止;
// 当其它线程用notify_one()将本wait(原来是阻塞)的状态唤醒后,这个wait就开始恢复干活了,恢复后wait干什么活?
// 1) wait()不断地尝试重新获取互斥量锁,如果获取不到,那么流程就卡在wait这里等着获取,如果获取到了锁(等于加了锁),那么wait就继续执行步骤2
// 2)
// 2-1) 如果wait有第二个参数(lambda),就判断这个lambda表达式,如果lambda表达式为false,那wait又对互斥量解锁,然后又休眠这里等待再次被notify_one()唤醒
// 2-2) 如果lambda表达式为true,则wait返回,流程走下去(此时互斥锁被锁着)
// 2-3) 如果wait没有第二个参数, 则wait返回,流程走下去
// my_cond.wait(lock,[this]{
// return !msgQueue.empty();
// });
// 流程走到这里来,这个互斥锁一定是锁着的
// 执行一些具体逻辑,假如耗时100ms(业务逻辑)
}
return 0;
}
假如正在执行业务逻辑(也就是上面所假设耗时100ms的地方),而不是正卡在wait()那里等待你唤醒,那么此时这个notify_one也许就没效果。
所以不要以为notify一次,就执行一次业务逻辑。也就是说没有相关线程在wait睡眠,那么notify_one没有用