设为首页 加入收藏

TOP

C/C++中如何精确计时
2013-09-24 09:22:35 来源: 作者: 【 】 浏览:134
Tags:C/C 如何 精确 计时

  给程序计时对于程序员来说实在是太重要了,在windows上的那个clock()实在是不够精确,精度只有10ms,真让人难过。研究了下windows下使用C、C++(www.cppentry.com)计时的函数,给大家分享下。

  主要就是两个函数的使用。我先把一段可以运行的代码贴出来,然后讲讲这两个函数。

  [cpp]

  1. #include <windows.h>

  2. #include <stdio.h>

  3. int main(int argc, char **argv)

  4. {

  5.     LARGE_INTEGER freq;

  6.     LARGE_INTEGER start_t, stop_t;

  7.     double exe_time;

  8.     QueryPerformanceFrequency(&freq);

  9.     fprintf(stdout, "The frequency of your pc is %d.\n", freq.QuadPart);

  10.     QueryPerformanceCounter(&start_t);

  11.     Sleep(1000);

  12.     QueryPerformanceCounter(&stop_t);  

  13.     exe_time = 1e3*(stop_t.QuadPart-start_t.QuadPart)/freq.QuadPart;

  14.     fprintf(stdout, "Your program executed time is %fms.\n", exe_time);

  15.     getchar();

  16.     return 0;

  17. }

  1、LARGE_INTEGER在微软的编译器中实际上是一个union,它的定义如下:

  [cpp]

  1. typedef union _LARGE_INTEGER

  2. {

  3.     struct

  4.     {

  5.         DWORD LowPart;

  6.         LONG HighPart;

  7.     };

  8.     struct

  9.     {

  10.         DWORD LowPart;

  11.         LONG HighPart;

  12.     } u;

  13.     LONGLONG QuadPart;

  14. } LARGE_INTEGER,  *PLARGE_INTEGER;

  如果你使用的编译器支持64位整数,那么可以使用QuadPart来引用变量的值。如果你的编译器不支持64位整数,那么可以使用LowPart和HighPart来引用64位整数的低32位和高32位。

  2、QueryPerformanceFrequncy(LARGE_INTEGER *freq)

  它用于获得你的机器一秒钟执行多少次,就是你的时钟周期。

  3、QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)

  它获得的是CPU从开机以来执行的时钟周期数。

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇C语言中typedef用法 下一篇C语言实现定积分求解方法

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: