您的位置:首页 > 其它

一个简单的用于性能测算的计时器函数

2012-04-20 08:55 447 查看
我们常常采用GetTickCount函数来测量程序的运行时间,但这个东西一次变化就要15~16ms,精度太低了。后果就是想要测量出个结果你得让代码反复运行很多次。

为此,我再次想到利用rdtsc指令。利用它给出的周期值,可以保证取到非常小的时间间隔。可惜的是该值不是直接的时间表达,还需要使用者按CPU主频去换算。不过很多时候我们仅仅是想比较两种不同方案的效率高低,那就直接看它们消耗的周期多少就可以了,无需换算成时间。

利用这个新函数,我们可以对ns级的变化也非常敏感,足以应付日常测试了。但须注意最好只用于测量单线程程序运行状况,在多线程时容易得到错误结论。另外,该函数自身大约需要消耗44个周期,在测试数据较小时应该从结果中去除这个值。

使用方法:

调用calculagraph(1),设置当前周期计数为基准周期值,同时返回它与上一次的基准周期值之间的差值。

调用calculagraph(0),返回当前周期计数与上一次基准之间的差值,但不改变基准周期值。

long long calculagraph(int flag)
{
static long long time;
long long curTime,delt;
__asm
{
rdtsc
mov dword ptr [curTime],eax
mov dword ptr [curTime+4],edx
}
delt=curTime-time;
if (flag)
time=curTime;
return delt;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: