本文主要是介绍C/C++中如何精确计时,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
给程序计时对于程序员来说实在是太重要了,在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从开机以来执行的时钟周期数。
转自C/C++中如何精确计时
这篇关于C/C++中如何精确计时的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!