C語言時間函數之mktime和difftime詳解

這兩個函數原型如下:

	__CRT_INLINE time_t __cdecl mktime(struct tm *_Tm);
	__CRT_INLINE double __cdecl difftime(time_t _Time1,time_t _Time2);

mktime函數

mktime函數會把參數把 timeptr 所指向的結構轉換為自 1970 年 1 月 1 日以來持續時間的秒數,如果發生錯誤時則返回-1。

參數結構體原型如下:

struct tm {
   int tm_sec;         /* 秒,范圍從 0 到 59                */
   int tm_min;         /* 分,范圍從 0 到 59                */
   int tm_hour;        /* 小時,范圍從 0 到 23              */
   int tm_mday;        /* 一月中的第幾天,范圍從 1 到 31  */
   int tm_mon;         /* 月份,范圍從 0 到 11              */
   int tm_year;        /* 自 1900 起的年數                    */
   int tm_wday;        /* 一周中的第幾天,范圍從 0 到 6    */
   int tm_yday;        /* 一年中的第幾天,范圍從 0 到 365 */
   int tm_isdst;       /* 夏令時                        */    
};

下面直接通過一段代碼來演示。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(int argc, char** argv)
{
    int ret,time_cnt;
    struct tm info;
    info.tm_year = 2022 - 1900;
    info.tm_mon = 1 - 1;
    info.tm_mday = 25;
    info.tm_hour = 11;
    info.tm_min = 28;
    info.tm_sec = 50;
    info.tm_isdst = -1;
    ret = mktime(&info);
    time_cnt = time(NULL);
    if( ret == -1 ) {
        printf("Error: unable to make time using mktime\n");
    } else {
        printf("%d %d",ret,time_cnt);
    }
    return 0;
}

首先定義時間結構體,然後給結構體中的變量賦值,將當前時間值賦給變量,然後在通過time函數獲取當前時間的秒數,最後將mktime函數轉換後的秒數和time函數返回的秒數打印出來。

image.png

通過結果可以看到兩個函數的秒數相差1,這是由於程序在編譯執行的時候延時瞭一秒,說明mktime函數轉換後的秒數和time函數返回的秒數是一樣的。

difftime函數

difftime函數有兩個時間參數,這個函數的主要作用返回這兩個時間就參數的差,也就是這兩個時間值相差的秒數。

一般可以通過這個函數來計算某段代碼運行的時間。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(int argc, char** argv)
{
	time_t start_t, end_t;
	double diff_t;
	printf("程序啟動...\n");
	time(&start_t);
	sleep(2);
	printf("運行結束!\n");
	time(&end_t);
	diff_t = difftime(end_t, start_t);
	printf("\n開始時間: %d 結束時間: %d 代碼運行時間: %fs\n", start_t,end_t,diff_t);
	return 0;
}

定義兩個變量來記錄程序運行前的時間值和程序運行後的時間值,然後通過延時函數來模擬程序的運行過程,最後通過difftime函數來計算函數運行的時長。

image.png

通過打印的結果可看出,延時函數的執行時間為2s,程序中的延時也是2s,說明函數計算的結果是正確的。在這裡要註意一點difftime函數的返回值是double類型的數據。

總結

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

推薦閱讀: