LARGE_INTEGER tima,timb; 
QueryPerformanceCounter(&tima);

在 Windows Server 2003 和 WindowsXP 中使用 QueryPerformanceCounter 函数的程序可能执行不当

QueryPerformanceCounter 來精確計算執行時間

QueryPerformanceCounter 來精確計算執行時間

// 這個程式展示了如何使用QueryPerformanceCounter 來精確計算執行時間

//代码

 

  1. LARGE_INTEGER m_liPerfFreq={0};
  2. //获取每秒多少CPU Performance Tick
  3. QueryPerformanceFrequency(&m_liPerfFreq);
  4. LARGE_INTEGER m_liPerfStart={0};
  5. QueryPerformanceCounter(&m_liPerfStart);
  6. for(int i=0; i< 100; i++)
  7. cout << i << endl;
  8. LARGE_INTEGER liPerfNow={0};
  9. // 计算CPU运行到现在的时间
  10. QueryPerformanceCounter(&liPerfNow);
  11. int time=( ((liPerfNow.QuadPart - m_liPerfStart.QuadPart) * 1000)/m_liPerfFreq.QuadPart);
  12. char buffer[100];
  13. sprintf(buffer,"執行時間 %d millisecond ",time);
  14. cout<<buffer<<endl;

QueryPerformanceCounter()这个函数返回高精确度性能计数器的值,它可以以微妙为单位计时.但是QueryPerformanceCounter()确切的精确计时的最小单位是与系统有关的,所以,必须要查询系统以得到QueryPerformanceCounter()返回的嘀哒声的频率.

QueryPerformanceFrequency()提供了这个频率值,返回每秒嘀哒声的个数.

计算确切的时间是从第一次调用QueryPerformanceCounter()开始的

假设得到的LARGE_INTEGER为nStartCounter,过一段时间后再次调用该函数结束的,

设得到nStopCounter.

两者之差除以QueryPerformanceFrequency()的频率就是开始到结束之间的秒数.由于计时函数本身要耗费很少的时间,要减去一个很少的时间开销.但一般都把这个开销忽略.公式如下:   

                         nStopCounter-nStartCounter 

ElapsedTime=------------------------------------ - overhead 

frequency 

double time=(nStopCounter.QuadPart-nStartCounter.QuadPart)/frequency.QuadPart

这两个函数是VC提供的仅供Windows 95及其后续版本使用的精确时间函数,并要求计算机从硬件上支持精确定时器。

QueryPerformanceFrequency()函数和QueryPerformanceCounter()函数的原型如下:

       BOOL  QueryPerformanceFrequency(LARGE_INTEGER *lpFrequency);
BOOL QueryPerformanceCounter(LARGE_INTEGER *lpCount);

  数据类型ARGE_INTEGER既可以是一个8字节长的整型数,也可以是两个4字节长的整型数的联合结构, 其具体用法根据编译器是否支持64位而定。该类型的定义如下:

       typedef union _LARGE_INTEGER
{
struct
{
DWORD LowPart ;// 4字节整型数
LONG HighPart;// 4字节整型数
};
LONGLONG QuadPart ;// 8字节整型数 }LARGE_INTEGER ;

  在进行定时之前,先调用QueryPerformanceFrequency()函数获得机器内部定时器的时钟频率, 然后在需要严格定时的事件发生之前和发生之后分别调用QueryPerformanceCounter()函数,利用两次获得的计数之差及时钟频率,计算出事件经 历的精确时间。下列代码实现1ms的精确定时:

 
  1. LARGE_INTEGER litmp;
  2. LONGLONG QPart1,QPart2;
  3. double dfMinus, dfFreq, dfTim;
  4. QueryPerformanceFrequency(&litmp);
  5. dfFreq = (double)litmp.QuadPart;// 获得计数器的时钟频率
  6. QueryPerformanceCounter(&litmp);
  7. QPart1 = litmp.QuadPart;// 获得初始值
  8. do
  9. {
  10. QueryPerformanceCounter(&litmp);
  11. QPart2 = litmp.QuadPart;//获得中止值
  12. dfMinus = (double)(QPart2-QPart1);
  13. dfTim = dfMinus / dfFreq;// 获得对应的时间值,单位为秒
  14. }while(dfTim<0.001);

  其定时误差不超过1微秒,精度与CPU等机器配置有关。 下面的程序用来测试函数Sleep(100)的精确持续时间:

 
  1. LARGE_INTEGER litmp;
  2. LONGLONG QPart1,QPart2;
  3. double dfMinus, dfFreq, dfTim;
  4. QueryPerformanceFrequency(&litmp);
  5. dfFreq = (double)litmp.QuadPart;// 获得计数器的时钟频率
  6. QueryPerformanceCounter(&litmp);
  7. QPart1 = litmp.QuadPart;// 获得初始值
  8. Sleep(100);
  9. QueryPerformanceCounter(&litmp);
  10. QPart2 = litmp.QuadPart;//获得中止值
  11. dfMinus = (double)(QPart2-QPart1);
  12. dfTim = dfMinus / dfFreq;// 获得对应的时间值,单位为秒

  由于Sleep()函数自身的误差,上述程序每次执行的结果都会有微小误差。下列代码实现1微秒的精确定时:

 
  1. LARGE_INTEGER litmp;
  2. LONGLONG QPart1,QPart2;
  3. double dfMinus, dfFreq, dfTim;
  4. QueryPerformanceFrequency(&litmp);
  5. dfFreq = (double)litmp.QuadPart;// 获得计数器的时钟频率
  6. QueryPerformanceCounter(&litmp);
  7. QPart1 = litmp.QuadPart;// 获得初始值
  8. do
  9. {
  10. QueryPerformanceCounter(&litmp);
  11. QPart2 = litmp.QuadPart;//获得中止值
  12. dfMinus = (double)(QPart2-QPart1);
  13. dfTim = dfMinus / dfFreq;// 获得对应的时间值,单位为秒
  14. }while(dfTim<0.000001);

其定时误差一般不超过0.5微秒,精度与CPU等机器配置有关。

【VS开发】QueryPerformanceFrequency与QueryPerformanceCounter的使用的更多相关文章

  1. QueryPerformanceFrequency 和 QueryPerformanceCounter用法

    QueryPerformanceFrequency() - 基本介绍 类型:Win32API 原型:BOOL QueryPerformanceFrequency(LARGE_INTEGER *lpFr ...

  2. C# 精准计时之 QueryPerformanceCounter QueryPerformanceFrequency用法

    C# 用法: public static class QueryPerformanceMethd { [DllImport("kernel32.dll")] public exte ...

  3. 时间的函数,sleep,clock,gettickcount,QueryPerformanceCounter(转)

    介绍 我 们在衡量一个函数运行时间,或者判断一个算法的时间效率,或者在程序中我们需要一个定时器,定时执行一个特定的操作,比如在多媒体中,比如在游戏中等,都 会用到时间函数.还比如我们通过记录函数或者算 ...

  4. QueryPerformanceFrequency使用方法--Windows高精度定时计数

    在多核心或多处理器的计算机上.特别是在支持CPU频率动态调整的计算机上,windows系统下的QueryPerformanceFrequency()获取HPET(假设存在)的频率,而QueryPerf ...

  5. QueryPerformanceFrequency

    var c1: int64; t1, t2: int64; QueryPerformanceFrequency(c1); QueryPerformanceCounter(t1); // GetSell ...

  6. QueryPerformanceFrequency 基本介绍精确获取时间

    精确获取时间: QueryPerformanceFrequency() - 基本介绍 类型:Win32API 原型:BOOL QueryPerformanceFrequency(LARGE_INTEG ...

  7. 【温故Delphi】GAEA用到Win32 API目录

    Delphi是Windows平台下著名的快速应用程序开发工具,它在VCL中封装并使用了大量的Win32 API. GAEA基于VCL开发的工具类产品,在程序中使用了大量的Win32 API,将经常用到 ...

  8. [原创]cocos2d-x研习录-第二阶 基本框架

    了解完Cocos2D-x的基本概念和概念类之后,是不是有一种蠢蠢欲动的冲动,想要探究Cocos2D-x是如何完成这一切的.接着我将通过对Cocos2D-x自代的HelloCpp项目进行分析,初步了解C ...

  9. Cocos2d-x内存管理研究<二>

    http://hi.baidu.com/tzkt623/item/46a26805adf7e938a3332a04   上一篇我们讲了内核是如何将指针加入管理类进行管理.这次我将分析一下内核是如何自动 ...

随机推荐

  1. Codeforces Round #585 (Div. 2) D. Ticket Game

    链接: https://codeforces.com/contest/1215/problem/D 题意: Monocarp and Bicarp live in Berland, where eve ...

  2. Linux文件删除的原理

    Linux文件iNode和block是否删除是通过  i_link  和 i_count 的计数值来判断的.只有i_count  和 I_link 同时为0 的 时候,文件的 iNode和block才 ...

  3. 【题解】Image Perimeters-C++

    题目Description给出一张由"x"和".“组成的矩阵.每个"x"可以向上下左右及两个斜对角进行连通,请问由某个点开始的"x”,它所连 ...

  4. 003_C/C++笔试题_分享大汇总

    (一)感谢:lhzstudio 01_C++经典面试题全集 50~100道 都附带有参考答案 02_C++开发工程师面试题库 100~150道 03_C++笔试题库之编程.问答题 150~200道 0 ...

  5. Web service stop after running serveral hours

    Error Message: 1. Error:Web service call "Test" execution failed 2. Error:<CENTER>&l ...

  6. leetcode解题报告(5):Longest Consecutive Sequence

    描述 Given an unsorted array of integers, find the length of the longest consecutive elements sequence ...

  7. luogu 4768

    kruskal 重构树对于一张无向图,我们在进行 kruskal 的过程中每当合并两个联通块时新建虚拟节点 t对于两个联通块的根节点 fau,fav 连无向边(fau, t),(fav, t) 其中点 ...

  8. 1558:聚会 ybt

    1558:聚会 ybt 题解(看似很难,其实要是摸清了实质这就是个大水题) 上题目 1558:聚会 时间限制: 1000 ms         内存限制: 524288 KB提交数: 82     通 ...

  9. ICEM-五通孔管

    原视频下载地址:https://yunpan.cn/cqaQ2t5DrRcKa  访问密码 d111

  10. MYSQL的两种存储引擎区别

    Innodb引擎 Innodb引擎提供了对数据库ACID事务的支持,并且实现了SQL标准的四种隔离级别.该引擎还提供了行级锁和外键约束,它的设计目标是处理大容量数据库系统,它本身其实就是基于MySQL ...