如何以亚秒级精度计时操作的持续时间?
Posted
技术标签:
【中文标题】如何以亚秒级精度计时操作的持续时间?【英文标题】:How to time the duration of an operation with subsecond accuracy? 【发布时间】:2018-12-15 11:57:35 【问题描述】:我想查找 OpenGL 帧的经过时间。我正在使用
self.start.elapsed().subsec_nanos(); // self.start is a std::time::Instant
它在我的笔记本电脑上运行良好。当我将代码放在 Raspberry Pi 上时,它不会编译,因为 subsec_nanos()
和 from_nanos()
不稳定。我尝试了 micros 和 millis,但它们似乎也不稳定。我已经在谷歌上搜索了一个小时,找不到任何其他方法可以让经过的时间少于一秒。我错过了什么明显的东西吗?
在我的笔记本电脑上,我正在运行 cargo 1.27.0 和 rustc 1.27.0。在 RPi 上,它们是
货物 0.26.0 和 rustc 1.25.0。我尝试了rustup update
,但得到了stable-armf7...update failed
我得到error[E0658] use of unstable library feature 'duration_extras'... (see #46507)
或'duration_from_micros'... (see #44400)
我不想每晚使用或对任何尝试代码的人提出复杂的安装要求。我希望他们能够使用标准的 vanilla rustup 安装过程。
【问题讨论】:
Duration::subec_nanos
自 1.3.0 以来一直稳定。
【参考方案1】:
当您卡在旧版 Rust 上时,您可以尝试流行的 time 库来计算日期时间。
【讨论】:
虽然这(也许)回答了这个问题,但展示一个演示如何获得亚秒级持续时间的示例会更有用。【参考方案2】:在 Raspberry Pi 上升级和安装当前版本似乎存在问题,请参阅:
rustup issue #1403 rustup issue #1410 Rust issue #49462查看完整的错误信息后,我注意到有两个错误:
最初是因为使用from_nanos()
设置每一帧的开始时间。
当我切换到使用 micros 或 millis 时,由于 subsec_micros()
或 subsec_millis()
而出现不同的错误
由于@DK says,subsec_nanos()
在 1.25.0 中是稳定的,最终的解决方案是与 Duration::new()
一起使用
let mut del = self.start.elapsed().subsec_nanos();
if del < self.target_frame_tm
let delay = Duration::new(0, (self.target_frame_tm - del) as u32);
sleep(delay);
del = self.target_frame_tm;
【讨论】:
以上是关于如何以亚秒级精度计时操作的持续时间?的主要内容,如果未能解决你的问题,请参考以下文章
springboot集成starrocks以及采用flink实现mysql与starrocks亚秒级同步