Windows 各種計時函式總結

2021-09-10 16:37:38 字數 3937 閱讀 6561

本文對windows平台下常用的計時函式進行總結,包括精度為秒、毫秒、微秒三種精度的5種方法。分為在標準c/c++下的二種time()及clock(),標準c/c++所以使用的time()及clock()不僅可以用在windows系統,也可以用於linux系統。在windows系統下三種,使用windows提供的api介面timegettime()、gettickcount()及queryperformancecounter()來完成。文章最後給出了5種計時方法示例**。

標準c/c++的二個計時函式time()及clock()

time_t time(time_t *timer);

返回以格林尼治時間(gmt)為標準,從2023年1月1日00:00:00到現在的此時此刻所經過的秒數。

time_t實際是個long長整型typedef long time_t;

標頭檔案:#include

clock_t clock(void);

返回程序啟動到呼叫函式時所經過的cpu時鐘計時單元(clock tick)數,在msdn中稱之為掛鐘時間(wal-clock),以毫秒為單位。

clock_t實際是個long長整型typedef long clock_t;

標頭檔案:#include

windows系統api函式

timegettime()、gettickcount()及queryperformancecounter()

dword timegettime(void);

返回系統時間,以毫秒為單位。系統時間是從系統啟動到呼叫函式時所經過的毫秒數。注意,這個值是32位的,會在0到2^32之間迴圈,約49.71天。

標頭檔案:#include

引用庫:#pragma comment(lib, "winmm.lib")  

dword winapi gettickcount(void);

這個函式和timegettime()一樣也是返回系統時間,以毫秒為單位。

標頭檔案:直接使用#include 就可以了。

高精度計時,以微秒為單位(1毫秒=1000微秒)。

先看二個函式的定義

bool queryperformancecounter(large_integer *lpperformancecount);

得到高精度計時器的值(如果存在這樣的計時器)。

bool queryperformancefrequency(large_integer *lpfrequency);

返回硬體支援的高精度計數器的頻率(次每秒),返回0表示失敗。

再看看large_integer

它其實是乙個聯合體,可以得到__int64 quadpart;也可以分別得到低32位dword lowpart和高32位的值long highpart。

在使用時,先使用queryperformancefrequency()得到計數器的頻率,再計算二次呼叫queryperformancecounter()所得的計時器值之差,用差去除以頻率就得到精確的計時了。

標頭檔案:直接使用#include 就可以了。

下面給出示例**,可以在你電腦上測試下。

//windows系統下time(),clock(),timegettime(),gettickcount(),queryperformancecounter()來計時 by morewindows

#include

#include

#include

//time_t time()  clock_t clock()

#include

//timegettime()

#pragma comment(lib, "winmm.lib")   //timegettime()

intmain

()

下面是本人電腦上的測試結果:

再分享一下我老師大神的人工智慧教程吧。零基礎!通俗易懂!風趣幽默!還帶黃段子!希望你也加入到我們人工智慧的隊伍中來!

本文對windows平台下常用的計時函式進行總結,包括精度為秒、毫秒、微秒三種精度的5種方法。分為在標準c/c++下的二種time()及clock(),標準c/c++所以使用的time()及clock()不僅可以用在windows系統,也可以用於linux系統。在windows系統下三種,使用windows提供的api介面timegettime()、gettickcount()及queryperformancecounter()來完成。文章最後給出了5種計時方法示例**。

標準c/c++的二個計時函式time()及clock()

time_t time(time_t *timer);

返回以格林尼治時間(gmt)為標準,從2023年1月1日00:00:00到現在的此時此刻所經過的秒數。

time_t實際是個long長整型typedef long time_t;

標頭檔案:#include

clock_t clock(void);

返回程序啟動到呼叫函式時所經過的cpu時鐘計時單元(clock tick)數,在msdn中稱之為掛鐘時間(wal-clock),以毫秒為單位。

clock_t實際是個long長整型typedef long clock_t;

標頭檔案:#include

windows系統api函式

timegettime()、gettickcount()及queryperformancecounter()

dword timegettime(void);

返回系統時間,以毫秒為單位。系統時間是從系統啟動到呼叫函式時所經過的毫秒數。注意,這個值是32位的,會在0到2^32之間迴圈,約49.71天。

標頭檔案:#include

引用庫:#pragma comment(lib, "winmm.lib")  

dword winapi gettickcount(void);

這個函式和timegettime()一樣也是返回系統時間,以毫秒為單位。

標頭檔案:直接使用#include 就可以了。

高精度計時,以微秒為單位(1毫秒=1000微秒)。

先看二個函式的定義

bool queryperformancecounter(large_integer *lpperformancecount);

得到高精度計時器的值(如果存在這樣的計時器)。

bool queryperformancefrequency(large_integer *lpfrequency);

返回硬體支援的高精度計數器的頻率(次每秒),返回0表示失敗。

再看看large_integer

它其實是乙個聯合體,可以得到__int64 quadpart;也可以分別得到低32位dword lowpart和高32位的值long highpart。

在使用時,先使用queryperformancefrequency()得到計數器的頻率,再計算二次呼叫queryperformancecounter()所得的計時器值之差,用差去除以頻率就得到精確的計時了。

標頭檔案:直接使用#include 就可以了。

下面給出示例**,可以在你電腦上測試下。

//windows系統下time(),clock(),timegettime(),gettickcount(),queryperformancecounter()來計時 by morewindows

#include

#include

#include

//time_t time()  clock_t clock()

#include

//timegettime()

#pragma comment(lib, "winmm.lib")   //timegettime()

intmain

()

下面是本人電腦上的測試結果:

Windows 各種計時函式總結

本文對windows平台下常用的計時函式進行總結,包括精度為秒 毫秒 微秒三種精度的5種方法。分為在標準c c 下的二種time 及clock 標準c c 所以使用的time 及clock 不僅可以用在windows系統,也可以用於linux系統。在windows系統下三種,使用windows提供的...

Windows 各種計時函式總結

本文對windows平台下常用的計時函式進行總結,包括精度為秒 毫秒 微秒三種精度的5種方法。分為在標準c c 下的二種time 及clock 標準c c 所以使用的time 及clock 不僅可以用在windows系統,也可以用於linux系統。在windows系統下三種,使用windows提供的...

Windows 各種計時函式總結

本文對windows平台下常用的計時函式進行總結,包括精度為秒 毫秒 微秒三種精度的5種方法。分為在標準c c 下的二種time 及clock 標準c c 所以使用的time 及clock 不僅可以用在windows系統,也可以用於linux系統。在windows系統下三種,使用windows提供的...