Issue of implementing profiling timer on some defective hardwares using QPF

6 篇文章 0 订阅

在使用QueryPerformanceCounter和QueryPerformanceFrequency来实现Timer时,需要注意一个问题,就是使用QPF计算所得,可能比GetTickCount来大许多,这可能是因为硬件问题造成的,所以可能需要修正(或者因为这些硬件太老了,也不需要修正?)。

 

相关的资料在微软的知识库中有介绍:

Performance counter value may unexpectedly leap forward
Ogre的OgreTimer中有相关的实现,可以参考。实现中有段代码是用来获取当前进程可以使用的processor的最小的Index
 
#if _MSC_VER >= 1400 && defined (_M_X64)
GetProcessAffinityMask(GetCurrentProcess(), (PDWORD_PTR)&procMask, (PDWORD_PTR)&sysMask);
#else
GetProcessAffinityMask(GetCurrentProcess(), &procMask, &sysMask);
#endif
// Find the lowest core that this process uses
if ( mTimerMask == 0 )
{
    // Alex, 2010.4.17
    // here, we can just compute the lowest as follow
    // ~(procMask & (procMask - 1)) & procMask
    // This assumes that procMask is non-zero, which could happen ?
    mTimerMask = 1;
    while ( ( mTimerMask & procMask ) == 0 )
    {
        mTimerMask <<= 1;
    }
}

这里其实可以不用循环而使用我在注释中提到的代码,因为只要提取最低的那个cpu bit就可以了。使用那段代码假定procMask不为0。(对于一个Process,它的procMask是否可能为0,如果为0,那么就是不允许在任何的cpu上执行,是否有意义?)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值