c++11的Condition_variable

先看官方介绍:

在下面这段代码中:

std::unique_lock <std::mutex> lck(mtx);
    while (!ready) // 如果标志位不为 true, 则等待...
        cv.wait(lck); // 当前线程被阻塞, 当全局标志位变为 true 之后,
    // 线程被唤醒, 继续往下执行打印线程编号id.
    std::cout << "thread " << id << '
';

线程先用unique_lock独占锁获取mutex互斥锁(构造函数自动获取,见下图用法3),然后在使用cv.wait()(cv是事前定义好的Condition_variable对象)时,会阻塞线程并自动释放持有的锁,见下下图,但是在其他线程使用cv.notify_all()或其他唤醒方式后,会重新获得锁mutex继续运行下面的逻辑。

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------

Happy Ending Every Day
原文地址:https://www.cnblogs.com/burningTheStar/p/6869796.html