C語(yǔ)言時(shí)間函數(shù)之mktime和difftime詳解
這兩個(gè)函數(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ù)會(huì)把參數(shù)把 timeptr 所指向的結(jié)構(gòu)轉(zhuǎn)換為自 1970 年 1 月 1 日以來(lái)持續(xù)時(shí)間的秒數(shù),如果發(fā)生錯(cuò)誤時(shí)則返回-1。
參數(shù)結(jié)構(gòu)體原型如下:
struct tm { int tm_sec; /* 秒,范圍從 0 到 59 */ int tm_min; /* 分,范圍從 0 到 59 */ int tm_hour; /* 小時(shí),范圍從 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; /* 夏令時(shí) */ };
下面直接通過(guò)一段代碼來(lái)演示。
#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; }
首先定義時(shí)間結(jié)構(gòu)體,然后給結(jié)構(gòu)體中的變量賦值,將當(dāng)前時(shí)間值賦給變量,然后在通過(guò)time函數(shù)獲取當(dāng)前時(shí)間的秒數(shù),最后將mktime函數(shù)轉(zhuǎn)換后的秒數(shù)和time函數(shù)返回的秒數(shù)打印出來(lái)。
通過(guò)結(jié)果可以看到兩個(gè)函數(shù)的秒數(shù)相差1,這是由于程序在編譯執(zhí)行的時(shí)候延時(shí)了一秒,說(shuō)明mktime函數(shù)轉(zhuǎn)換后的秒數(shù)和time函數(shù)返回的秒數(shù)是一樣的。
difftime函數(shù)
difftime函數(shù)有兩個(gè)時(shí)間參數(shù),這個(gè)函數(shù)的主要作用返回這兩個(gè)時(shí)間就參數(shù)的差,也就是這兩個(gè)時(shí)間值相差的秒數(shù)。
一般可以通過(guò)這個(gè)函數(shù)來(lái)計(jì)算某段代碼運(yùn)行的時(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("程序啟動(dòng)...\n"); time(&start_t); sleep(2); printf("運(yùn)行結(jié)束!\n"); time(&end_t); diff_t = difftime(end_t, start_t); printf("\n開始時(shí)間: %d 結(jié)束時(shí)間: %d 代碼運(yùn)行時(shí)間: %fs\n", start_t,end_t,diff_t); return 0; }
定義兩個(gè)變量來(lái)記錄程序運(yùn)行前的時(shí)間值和程序運(yùn)行后的時(shí)間值,然后通過(guò)延時(shí)函數(shù)來(lái)模擬程序的運(yùn)行過(guò)程,最后通過(guò)difftime函數(shù)來(lái)計(jì)算函數(shù)運(yùn)行的時(shí)長(zhǎng)。
通過(guò)打印的結(jié)果可看出,延時(shí)函數(shù)的執(zhí)行時(shí)間為2s,程序中的延時(shí)也是2s,說(shuō)明函數(shù)計(jì)算的結(jié)果是正確的。在這里要注意一點(diǎn)difftime函數(shù)的返回值是double
類型的數(shù)據(jù)。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(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-11C++中template方法undefined reference to的問題解決
Undefined reference to 錯(cuò)誤:這類錯(cuò)誤是在連接過(guò)程中出現(xiàn)的,本文就來(lái)介紹一下C++中template方法undefined reference to的問題解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03淺談C++ Explicit Constructors(顯式構(gòu)造函數(shù))
下面小編就為大家?guī)?lái)一篇淺談C++ Explicit Constructors(顯式構(gòu)造函數(shù))。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12詳解Dev C++使用教程(使用Dev C++編寫C語(yǔ)言程序)
這篇文章主要介紹了詳解Dev C++使用教程(使用Dev C++編寫C語(yǔ)言程序),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03C++中使用FFmpeg適配自定義編碼器的實(shí)現(xiàn)方法
本文介紹了在C++中使用FFmpeg庫(kù)進(jìn)行自定義編碼器適配的實(shí)現(xiàn)方法。文章通過(guò)具體的代碼示例,介紹了FFmpeg的基本使用方法和自定義編碼器的實(shí)現(xiàn)過(guò)程,幫助讀者了解如何在C++中進(jìn)行音視頻編碼和解碼的開發(fā)工作,并能夠?qū)崿F(xiàn)自定義的編碼器適配2023-04-04