我处于以下情况:
我想确定(PHP 和 C++)代码的小片段的系统和用户时间。显然,我可以在 Linux 中使用“time”二进制文件,但考虑到这些片段运行得如此之快,“time”的正常(甚至详细)输出不足以满足我的目的。 “时间”的精度达到毫秒,而我需要微秒。甚至更好:纳秒。
任何人都可以向我指出一款可以为我做到这一点的软件吗?我找到了walltime的东西,但我感兴趣的是sys-和usertime。
提前致谢!
顺便说一句:我正在运行 Ubuntu 10.10 64 位
最佳答案
没有任何方法可以为您提供任何与 time
命令报告的 sys 或 usertime 等效的更精确的信息。 time
命令的许多明显精度实际上是错误的精度。
处理这个问题的技术是将这些代码片段放在调用它们数千次的紧密循环中,并计算出给定循环需要多长时间。即便如此,您也应该重复实验几次并选择最低的时间。
这是一个类比,描述了为什么精度是错误的,以及我的意思。假设您有人使用秒表为比赛计时,在比赛开始时和被计时的人越过终点线时手动按下按钮。据说你的秒表精确到 100 秒。但这种精确度是错误的,因为它与按下按钮的人的 react 时间所引入的错误相形见绌。
这与为什么 time
为您提供据称以微秒为单位的准确性非常相似,但实际上明显不那么精确。在任何给定的时间点,在任何给定的系统中都会发生很多事情,所有这些都会在计算中引入错误。来自网络 IO 或磁盘 IO 的中断、用于运行调度程序的定时器中断、其他进程对 L1 或 L2 CPU 缓存所做的事情。这一切都加起来了。
使用类似 valgrind
之类的东西在模拟 CPU 上运行您的程序可以为您提供看似准确的 CPU 周期数。但是这种精确度并不是您在现实世界中所体验到的。最好使用我最初描述的技术并接受这些时间可能是模糊的。
关于linux - 关于 sys- 和 usertime,Linux 中 "time"命令的更准确等价物?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4238547/