c++ - `std::condition_variable::wait_for` 经常调用谓词
问题描述
考虑以下代码片段:
#include <iostream>
#include <condition_variable>
#include <chrono>
#include <mutex>
int main () {
std::mutex y;
std::condition_variable x;
std::unique_lock<std::mutex>lock{y};
int i = 0;
auto increment = [&] {++i; return false;};
using namespace std::chrono_literals;
//lock 5s if increment returns false
//let's see how often was increment called?
x.wait_for(lock, 5s, increment);
std::cout << i << std::endl;
//compare this with a simple loop:
//how often can my system call increment in 5s?
auto const end = std::chrono::system_clock::now() + 5s;
i = 0;
while (std::chrono::system_clock::now() < end) {
increment();
}
std::cout << i;
}
据我了解wait_for,i
应该是O(1)之后wait_for
(假设虚假解锁很少见)。
但是,我得到
i ~= 3e8
了kernel 4.17.14, Intel(R) Core(TM) i7-6700 CPU @ 3.40GHz
,
i ~= 8e6
因为kernel 3.10.0, Intel(R) Xeon(R) CPU E5-2630 v4 @ 2.20GHz
。
这听起来很有趣,所以我通过与一个运行 5 秒的简单循环进行比较来检查。的结果大致相同i
,只有 5-10% 的差异。
问题:
在wait_for
做什么?它是否按预期工作,我只是理解 cppreference 错误,还是我搞砸了?
第二,(可选)问题:这种巨大的差异i
从何而来?
附加信息:( gcc7.3
, gcc8.2
, clang6.0
),标志:-O3 --std=c++17
都产生可比较的结果。
解决方案
libstdc++ 有一种不幸的编译能力,并且似乎在没有 pthread 的情况下也能正常工作,但它不能正常工作。
请参阅此 libstdc++ 错误:https ://gcc.gnu.org/bugzilla/show_bug.cgi?id=58929
您需要添加"-pthread"
到您的编译命令。
推荐阅读
- python - 在 python 中捕获特定错误
- ios - 覆盖“shouldPerformSegueWithIdentifier”函数抛出错误
- .net - 尽管使用了 XDocument,但 XML 中的字符无效
- javascript - 为什么我的代码在没有 .remove() 的情况下删除对象
- android - 如何调整文本对齐到文本视图的两个角
- gradle - Gradle Release Plugin:如何将版本保存在文本文件(而不是属性文件)中?
- java - 如何在用户关闭应用程序时启用推送通知并在用户打开应用程序时禁用
- algorithm - 如何计算具有循环依赖关系的有向图中的变化顶点权重?
- audio - 如何转换音频并跟踪所有格式的元数据
- android - 使用 View.GenerateViewId 创建 ID 时如何使用 ID 查找 TextView