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

我们常常采用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;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值