給程序計時對於程序員來說實在是太重要了,在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從開機以來執行的時鐘周期數。