如何以亚秒级精度计时操作的持续时间?

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;

【讨论】:

以上是关于如何以亚秒级精度计时操作的持续时间?的主要内容,如果未能解决你的问题,请参考以下文章

将时间与亚秒级精度进行比较

毫秒分辨率计时器是LinkIT 7688

springboot集成starrocks以及采用flink实现mysql与starrocks亚秒级同步

Quick BI产品核心功能大图:Quick引擎加速--十亿数据亚秒级分析

clickhouse微信基于Clickhouse的实时数仓

谷歌应用引擎 GQL,如何以毫秒精度使用日期时间进行分页