QueryPerformanceCounter()是一个微秒级的高精度的时间函数。
QueryPerformanceFrequency()获得的是CPU的滴答数(频率),现在频率一般为1000。那么CPU的周期也就是1/1000的1us。
QueryPerformanceCounter()和QueryPerformanceFrequency()需要配合使用
QueryPerformanceCounter()这个函数返回高精确度性能计数器的值,它可以以微妙为单位计时.但是QueryPerformanceCounter()确切的精确计时的最小单位是与系统有关的,所以,必须要查询系统以得到QueryPerformanceCounter()返回的嘀哒声的频率.
**用途 : **我们可以使用QueryPerformanceCounter()去获得一段高精度的时间差。
**使用方法:**调用俩次QueryPerformanceCounter(),然后相减得到的差去除以QueryPerformanceFrequency()获得的滴答数,就可以得到高精度的时间差。
QueryPerformanceCounter(&StartTime);
QPart1 = StartTime.QuadPart; // 获得初始值
sleep(1);
QueryPerformanceCounter(&StartTime);
QPart2 = StartTime.QuadPart; //获得终止值
dfMinus = QPart2 - QPart1; //查
dfTim = dfMinus / dfFreq;// 获得对应的时间值,单位为秒
但实际上,当我们运行这段代码的时候,获得的时间差并不精确。
这是为什么呢?
实际上,我们只关注了QPC函数是一个高精度的时间函数,但sleep()却并不是一个精准的时间函数,因为它基于非常慢的时钟,并且依赖于操作系统在周期结束时恢复执行。所以会造成较大的误差。
所以在使用的时候,我们一定要关注到这一点。