什么时候可以在没有谓词的情况下使用 std::condition_variable
When can std::condition_variable be used without a predicate?
如果由于虚假唤醒而可以发出std::condition_variable
信号(并且我们无法确定我们需要的条件是否真的满足),为什么C++标准库提供wait()
方法的重载而没有谓词?可以使用这种行为的场景是什么?
假设一个复杂的条件:A || B
。当条件的任何部分为真时,应执行适当的操作,actionA
或actionB
。
使用谓词版本,代码可能如下所示:
cond.wait(lock, []{return (A || B);});
if(A) {
actionA();
}
else {
actionB();
}
但是如果使用非谓词等待,代码可能会更快:
while(true)
{
if(A) {
actionA();
break;
}
else if(B) {
actionB();
break;
}
cond.wait(lock);
}
请注意,与第一个变体不同,现在每个条件部分都评估一次。
在更复杂的情况下,条件不能写在单个表达式中。
为什么C++标准库提供没有谓词的wait()方法重载
wait
的谓词版本等效于:
while (!pred()) {
wait(lock);
}
如果需要在等待之前和/或之后执行更复杂的代码,您可能希望使用不带谓词的wait
。
我想在某些情况下,虚假唤醒并不是世界末日。
例如,考虑一个生产者-消费者批处理系统,当队列中至少有 100 条消息时,某个线程应该唤醒并处理它们。
给定虚假唤醒,它偶尔可能会收获少于 100 条消息。 这种差异可能不保证条件函数的开销和额外复杂性。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么 std::unique 不调用 std::sort?
- 使用std::函数映射对象方法
- 我需要std::condition,但有两个以上的选择