C++ Coder

HCP高性能计算架构,实现,编译器指令优化,算法优化, LLVM CLANG OpenCL CUDA OpenACC C++AMP OpenMP MPI

C++博客 首页 新随笔 联系 聚合 管理
  98 Posts :: 0 Stories :: 0 Comments :: 0 Trackbacks
http://blog.csdn.net/bendanban/article/details/7673607
给程序计时对于程序员来说实在是太重要了,在windows上的那个clock()实在是不够精确,精度只有10ms,真让人难过。研究了下windows下使用C、C++计时的函数,给大家分享下。

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

#include <windows.h>
#include 
<stdio.h>
int main(int argc, char **argv)
{
    LARGE_INTEGER freq;
    LARGE_INTEGER start_t, stop_t;
    
double exe_time;
    QueryPerformanceFrequency(
&freq);
    fprintf(stdout, 
"The frequency of your pc is %d.\n", freq.QuadPart);
    QueryPerformanceCounter(
&start_t);
    Sleep(
1000);
    QueryPerformanceCounter(
&stop_t);
    exe_time 
= 1e3*(stop_t.QuadPart-start_t.QuadPart)/freq.QuadPart;
    fprintf(stdout, 
"Your program executed time is %fms.\n", exe_time); 
    getchar();
    
return 0;
}

 

1、LARGE_INTEGER在微软的编译器中实际上是一个union,它的定义如下:
typedef union _LARGE_INTEGER
{  
    
struct
 
    
{    
        DWORD LowPart;   
        LONG HighPart;  
    }

    
struct
 
    
{   
        DWORD LowPart;    
        LONG HighPart;  
    }
 u;  
    LONGLONG QuadPart;
}
 LARGE_INTEGER,  *PLARGE_INTEGER;


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

2、QueryPerformanceFrequncy(LARGE_INTEGER *freq)

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

3、QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)

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

 

O啦。。。。好好用用它吧。






posted on 2012-10-21 12:45 jackdong 阅读(503) 评论(0)  编辑 收藏 引用 所属分类: C/C++

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理