C語言時間函數(shù)之mktime和difftime詳解
這兩個函數(shù)原型如下:
__CRT_INLINE time_t __cdecl mktime(struct tm *_Tm); __CRT_INLINE double __cdecl difftime(time_t _Time1,time_t _Time2);
mktime函數(shù)
mktime函數(shù)會把參數(shù)把 timeptr 所指向的結(jié)構(gòu)轉(zhuǎn)換為自 1970 年 1 月 1 日以來持續(xù)時間的秒數(shù),如果發(fā)生錯誤時則返回-1。
參數(shù)結(jié)構(gòu)體原型如下:
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 起的年數(shù) */
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;
}
首先定義時間結(jié)構(gòu)體,然后給結(jié)構(gòu)體中的變量賦值,將當(dāng)前時間值賦給變量,然后在通過time函數(shù)獲取當(dāng)前時間的秒數(shù),最后將mktime函數(shù)轉(zhuǎn)換后的秒數(shù)和time函數(shù)返回的秒數(shù)打印出來。

通過結(jié)果可以看到兩個函數(shù)的秒數(shù)相差1,這是由于程序在編譯執(zhí)行的時候延時了一秒,說明mktime函數(shù)轉(zhuǎn)換后的秒數(shù)和time函數(shù)返回的秒數(shù)是一樣的。
difftime函數(shù)
difftime函數(shù)有兩個時間參數(shù),這個函數(shù)的主要作用返回這兩個時間就參數(shù)的差,也就是這兩個時間值相差的秒數(shù)。
一般可以通過這個函數(shù)來計算某段代碼運行的時間。
#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("運行結(jié)束!\n");
time(&end_t);
diff_t = difftime(end_t, start_t);
printf("\n開始時間: %d 結(jié)束時間: %d 代碼運行時間: %fs\n", start_t,end_t,diff_t);
return 0;
}
定義兩個變量來記錄程序運行前的時間值和程序運行后的時間值,然后通過延時函數(shù)來模擬程序的運行過程,最后通過difftime函數(shù)來計算函數(shù)運行的時長。

通過打印的結(jié)果可看出,延時函數(shù)的執(zhí)行時間為2s,程序中的延時也是2s,說明函數(shù)計算的結(jié)果是正確的。在這里要注意一點difftime函數(shù)的返回值是double類型的數(shù)據(jù)。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++編程析構(gòu)函數(shù)拷貝構(gòu)造函數(shù)使用示例詳解
這篇文章主要為大家介紹了C++編程構(gòu)造函數(shù)中析構(gòu)函數(shù)及拷貝構(gòu)造函數(shù)的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-11-11
C++中template方法undefined reference to的問題解決
Undefined reference to 錯誤:這類錯誤是在連接過程中出現(xiàn)的,本文就來介紹一下C++中template方法undefined reference to的問題解決,具有一定的參考價值,感興趣的可以了解一下2024-03-03
淺談C++ Explicit Constructors(顯式構(gòu)造函數(shù))
下面小編就為大家?guī)硪黄獪\談C++ Explicit Constructors(顯式構(gòu)造函數(shù))。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12
詳解Dev C++使用教程(使用Dev C++編寫C語言程序)
這篇文章主要介紹了詳解Dev C++使用教程(使用Dev C++編寫C語言程序),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
C++中使用FFmpeg適配自定義編碼器的實現(xiàn)方法
本文介紹了在C++中使用FFmpeg庫進行自定義編碼器適配的實現(xiàn)方法。文章通過具體的代碼示例,介紹了FFmpeg的基本使用方法和自定義編碼器的實現(xiàn)過程,幫助讀者了解如何在C++中進行音視頻編碼和解碼的開發(fā)工作,并能夠?qū)崿F(xiàn)自定義的編碼器適配2023-04-04

