C語言中的時間函數clock()和time()你都瞭解嗎

時間函數在編寫代碼的時候會經常用到,下面就來總結一下clocktime函數的用法,函數原型如下:

  clock_t __cdecl clock(void);
  __CRT_INLINE time_t __cdecl time(time_t *_Time);

clock函數

clock函數返回程序從運行開始到當前調用函數位置處CPU所使用的時間,通過這個函數就可以計算某段代碼運行時所使用的時間。

下面通過一段簡單的代碼測試一下:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(int argc, char** argv)
{
	clock_t start_t, end_t;
	start_t = clock();
	sleep(1);
	end_t = clock();
	printf("%d %d",start_t,end_t); 
	return 0;
}

剛進入程序時通過clock函數讀取當前CPU所使用的時間,然後使用sleep函數延時1秒,接著在使用clock函數讀取當前CPU所使用的時間,這樣這兩個時間差應該就是1秒。程序運行結果如下:

image.png

通過打印的結果可以看出,第一次讀取的CPU時間是0,第二次讀取的CPU時間是1000,在程序中延時瞭1秒,說明clock函數返回的時間單位是毫秒(ms)。

如果要將程序運行的時間換算為以秒為單位的話,這裡就需要計算兩次運行的時間差,然後除以每秒鐘系統的計數次數。系統中每秒鐘的計數次數用一個宏定義的值來表示。

#define CLOCKS_PER_SEC 1000

這個CLOCKS_PER_SEC的值為1000,說明CPU1秒鐘計數1000次,也就是1ms計數一次,這個和上面分析的結果是一樣的。

修改程序,將時間換算為秒,繼續測試。

image.png

通過結果可以看出這個循環耗時32ms,也就是0.032s。

time函數

time函數返回的是從 1970-01-01 00:00:00 開始到現在所經過的秒數。

下面通過一個簡單的代碼演示一下time函數的用法。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(int argc, char** argv)
{
	time_t seconds;
	seconds = time(NULL);
	printf("自1970-01-01 起的秒數:%d s",seconds);
	return 0;
}

time函數返回值是一個time_t的類型,它的本質其實也是一個整形數據。

image.png

函數返回的是一個整形的秒數,將返回值打印出來,結果如下:

image.png

將這個秒數通過時間戳在線轉換網站轉換為年月日,轉換網址為: https://tool.lu/timestamp/ 轉換結果如下:

image.png

轉換後的時間和程序運行時的時間是一樣的,說明time函數返回的時間是準確的,這樣在程序運行過程中想要獲取準確的時間時,就可以通過time函數來獲取系統的準確時間。

總結

本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!    

推薦閱讀: