执行时间的准确变化

Posted

技术标签:

【中文标题】执行时间的准确变化【英文标题】:Accurate changes in execution time 【发布时间】:2014-04-27 16:15:44 【问题描述】:

我正在寻找一种方法来非常准确地测量程序的执行时间。作为练习的一部分,我试图对一个文件执行侧通道攻击,该文件将我的命令行参数与长度为 19 的密码进行比较。对于每个错误的字符,执行进入一个嵌套循环。

我正在考虑编写一个执行包装器,我的程序将在其中分叉,父级将执行练习二进制文件,子级将等待父级并计算从分叉向前到等待的执行时间(&status);打电话。

这是一个好方法吗?我可以探索哪些其他选择?在尝试以良好的精确度计时执行时,我最好的选择是什么?

【问题讨论】:

测量 CPU 时间还是挂墙时间? 你考虑过系统调用gettimeofday()吗? 【参考方案1】:

除非您有非常具体的要求,否则您可以使用/bin/timetime(具有类似功能的shell 内置)。

【讨论】:

time 使用 gettimeofday() 吗?另外,当你的 cpu 很弱时,当time 被交换时会发生什么? @lrobb 我不这么认为,它会使用times(2)getrusage(2)等系统调用,但我没有检查细节。有兴趣的可以查看sources of GNU version of time。

以上是关于执行时间的准确变化的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Django 中每天一次在准确的时间执行命令?

为啥程序的执行时间会发生显着变化?

为啥这个函数调用的执行时间会发生变化?

为啥while循环的执行速度会随时间变化?

使用神经网络执行文本分类时,准确性和损失之间是不是存在直接关系?

SQL 执行计划 - 估计计划似乎比实际计划更准确