boyqd的笔记 https://bbs.21ic.com/?794795 [收藏] [复制] [RSS]

日志

C中如何精确计时

已有 682 次阅读2012-6-29 01:42 |系统分类:网上好文

    给程序计时对于程序员来说实在是太重要了,在windows上的那个clock()实在是不够精确,精度只有10ms,真让人难过。研究了下windows下使用C、C++计时的函数,给大家分享下。
主要就是两个函数的使用。我先把一段可以运行的代码贴出来,然后讲讲这两个函数。
[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);   www.2cto.com
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从开机以来执行的时钟周期数。



路过

鸡蛋

鲜花

握手

雷人

评论 (0 个评论)