测量执行时间 - 在程序代码或外壳中
Measuring execution time - in program code or in shell?
我有一个程序,我想测量其执行时间(wallclock(时间的不同输入尺寸的时间。
在其他一些类似的问题中,我读到,在源代码中使用clock_gettime
是由于CPU分支预测器,注册重命名,投机执行,排序执行等方移动clock_gettime
除了我放置的地方以外的其他地方。
,但是我读到的这些问题是关于衡量特定功能的时间。如果我要衡量整个程序(即main
函数(,这些问题仍然存在吗?我正在寻找相对测量值,执行时间如何变化不同的输入大小,而不是绝对值。
我将如何获得更好的结果?在代码中使用定时功能:
start = clock_gettime();
do_stuff();
end = clock_gettime();
execution_time = end - start;
或用bash
中的time
命令:
time ./program
在程序中进行测量将为您提供更准确的答案。当然,从理论上讲,在某些情况下,您可以将clock_gettime
调用转移到您不期望的地方。实际上,如果您只有一个函数调用,则不会发生。(如果有疑问,请检查结果组件代码(
在Shell中调用time
将包括您不在乎的事情,例如加载可执行文件并提交有趣的观点所需的时间。另一方面,如果您的do_stuff
花了几秒钟,那并不重要。
我会选择以下建议:
- 如果您可以轻松隔离功能并使其花费几秒钟(您也可以循环循环,但也可以测量空循环进行比较(,则
clock_gettime
或time
可以很好。 - 如果您不能轻易隔离,但是您的功能始终如一地占用数百毫秒,请使用
clock_gettime
。 - 如果您无法隔离并且正在优化微小的东西,请查看rdtsc的时间安排,以测量一个函数,该功能谈论测量实际执行的周期。
相关文章:
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 代码在main()中运行,但在函数中出现错误
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- 编译包含字符串的代码时遇到问题
- 我在c++代码中生成了一个运行时#3异常
- 如何在linux终端中同时编译和运行c++代码
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 在Linux for Windows上编译C++代码时出错
- 我的字符计数代码计算错误.为什么
- 孤立代码块在结构中引发异常
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 此代码是否违反一个定义规则
- 为什么我的代码在输出中增加了93天
- 如何获取包含 NULL 字符的外壳代码字符串的长度
- 测量执行时间 - 在程序代码或外壳中
- 在 cpp 中运行外壳代码
- 缓冲区溢出的外壳代码如何生成
- 在Visual C++中,通过强制转换为函数指针来执行外壳代码