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)體中的變量賦值,將當前時間值賦給變量,然后在通過time函數(shù)獲取當前時間的秒數(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-11C++中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語言程序),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-03-03C++中使用FFmpeg適配自定義編碼器的實現(xiàn)方法
本文介紹了在C++中使用FFmpeg庫進行自定義編碼器適配的實現(xiàn)方法。文章通過具體的代碼示例,介紹了FFmpeg的基本使用方法和自定義編碼器的實現(xiàn)過程,幫助讀者了解如何在C++中進行音視頻編碼和解碼的開發(fā)工作,并能夠?qū)崿F(xiàn)自定義的編碼器適配2023-04-04