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開(kāi)始時(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類(lèi)型的數(shù)據(jù)。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Qt使用SqlLite實(shí)現(xiàn)權(quán)限管理的示例代碼
本文主要介紹了Qt使用SqlLite實(shí)現(xiàn)權(quán)限管理的示例代碼,管理員針對(duì)不同人員進(jìn)行權(quán)限設(shè)定,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
詳解C語(yǔ)言實(shí)現(xiàn)空間索引四叉樹(shù)
本文主要介紹了用C語(yǔ)言實(shí)現(xiàn)四叉樹(shù),對(duì)算法感興趣的同學(xué),可以參考下,并且試驗(yàn)一下。2021-05-05
C++回文數(shù)及素?cái)?shù)問(wèn)題計(jì)算方法
這篇文章主要介紹了C++回文數(shù)及素?cái)?shù)問(wèn)題計(jì)算方法,可實(shí)現(xiàn)一定范圍內(nèi)的素?cái)?shù)與回文數(shù)運(yùn)算功能,涉及C++字符串遍歷與數(shù)字?jǐn)?shù)學(xué)運(yùn)算的相關(guān)技巧,需要的朋友可以參考下2016-05-05
在Visual Studio 2019中修改項(xiàng)目名的方法
這篇文章主要介紹了在Visual Studio 2019中修改項(xiàng)目名的方法,文中通過(guò)示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之二分法查找詳解
二分查找算法是在有序數(shù)組中用到的較為頻繁的一種算法,在未接觸二分查找算法時(shí),最通用的一種做法是,對(duì)數(shù)組進(jìn)行遍歷,跟每個(gè)元素進(jìn)行比較,其時(shí)間為O(n),但二分查找算法更優(yōu)2022-02-02

