C語(yǔ)言中時(shí)間的基本用法小結(jié)
前言
在我學(xué)的這些編程語(yǔ)言中,總是記不住它們的時(shí)間處理方式,每次用到時(shí)都要重新看,所以想著在這里記錄下來(lái),也方便用到時(shí)查找,也方便有需要的朋友們參考。
time_t和struct tm
在C語(yǔ)言中用time_t
類(lèi)型表示一個(gè)時(shí)間,通常它是一個(gè)和long
一樣長(zhǎng)的整數(shù),也就是說(shuō),在32位環(huán)境下,它是4字節(jié),在64位環(huán)境下,它是8字節(jié)。它保存的就是一個(gè)整數(shù)值,表示了從1970-01-01 08:00:00到其所表示時(shí)間的秒數(shù),它是一個(gè)非負(fù)整數(shù),所以,time_t無(wú)法表示早于1970-01-01 08:00:00的時(shí)間。
一個(gè)很常用的函數(shù)就是time_t time(time_t *_v)
,它的參數(shù)是一個(gè)time_t
類(lèi)型的指針,返回一個(gè)和傳入?yún)?shù)相等的time_t
類(lèi)型值。如果time()
函數(shù)的參數(shù)是0,則返回當(dāng)前的時(shí)間。
現(xiàn)在我們已經(jīng)能用C語(yǔ)言表示一個(gè)時(shí)間了,但是這個(gè)時(shí)間只是從某個(gè)時(shí)間開(kāi)始的秒數(shù),如何表示更詳細(xì)的時(shí)間細(xì)節(jié)呢?這就要用到struct tm
類(lèi)型了,它可以表示更具體的時(shí)間信息。
它一個(gè)結(jié)構(gòu)體,我們就先看一下它的成員信息,一個(gè)struct tm
類(lèi)型包括以下成員:
int tm_year
表示時(shí)間的年份,它的值從1900年開(kāi)始算起,也就是說(shuō)當(dāng)其值為1的時(shí)候,表示的是1901年。因?yàn)?code>time_t類(lèi)型表示的時(shí)間范圍不早于1970年,所以這個(gè)值通常不小于70。int tm_mon
表示時(shí)間是幾月,它的值是0到11,0表示的是一月,而11表示的是12月。int tm_mday
表示時(shí)間是當(dāng)前月的幾號(hào),其值的范圍自然是根據(jù)月份不同也不相同。int tm_wday
表示時(shí)間是星期幾,它的值的范圍是0到6,0是星期天,1是星期一,6是星期六。int tm_yday
表示時(shí)間是當(dāng)前年的第幾天,要注意的是1月1號(hào)是第0天。int tm_hour
表示時(shí)間是幾時(shí)。int tm_min
表示時(shí)間是幾分。int tm_sec
表示時(shí)間是幾秒。int tm_isdst
表示是否是夏令時(shí)。
localtime()
如何把一個(gè)time_t
類(lèi)型構(gòu)造成struct tm
類(lèi)型呢?用struct tm *localtime(const time_t *_v)
函數(shù)即可,注意參數(shù)和返回值都是指針類(lèi)型。
#include <stdio.h> #include <time.h> int main() { time_t tt = time(0); //獲取當(dāng)前時(shí)間 struct tm *pst = localtime(&tt); //把time_t類(lèi)型轉(zhuǎn)換為struct tm類(lèi)型 printf("The year is %d.\n", pst->tm_year + 1900); //別忘了要加1900 return 0; }
上述程序輸出:
The year is 2016.
mktime()
那么如何把struct tm
類(lèi)型轉(zhuǎn)換為time_t
類(lèi)型呢?就用time_t mktime(struct tm *_v)
函數(shù),注意參數(shù)是指針類(lèi)型。
那么如何輸出時(shí)間呢?可以簡(jiǎn)單的使用char *ctime(time_t *_v)
函數(shù)和char *asctime(struct tm *_v)
函數(shù),要注意的是返回的字符串結(jié)尾包含換行符\n。
#include <stdio.h> #include <time.h> int main() { struct tm st; st.tm_year = 2016 - 1900; st.tm_mon = 8; st.tm_mday = 13; st.tm_hour = 16; st.tm_min = 30; st.tm_sec = 0; st.tm_isdst = 0; time_t tt = mktime(&st); printf("%s", asctime(&st)); printf("%s", ctime(&tt)); return 0; }
上述程序輸出:
Tue Sep 13 16:30:00 2016 Tue Sep 13 16:30:00 2016
我們自己用struct tm
構(gòu)造了一個(gè)時(shí)間,并且在執(zhí)行mktime()
函數(shù)后,tm_wday
屬性也會(huì)自動(dòng)計(jì)算出來(lái)。
clock()
在time.h中,還有一些其他很常用的函數(shù),比如clock_t clock()
函數(shù),clock_t
也是一個(gè)整數(shù),是typedef long clock_t;
得來(lái)的。這個(gè)函數(shù)返回程序運(yùn)行到這條語(yǔ)句所消耗的時(shí)間。單位一般是毫秒,可以通過(guò)printf("%d\n", CLOCKS_PER_SEC);
這樣確定,若輸出1000,則證明是毫秒。
我們可以方便的用它來(lái)計(jì)算程序某一段語(yǔ)句所消耗的時(shí)間:
#include <stdio.h> #include <time.h> int main() { int i = 0; printf("CLOCKS_PER_SEC: %ld\n", CLOCKS_PER_SEC); long c = clock(); while(i < 1<<30) i++; printf("The while loop cost %ld.\n", clock() - c); c = clock(); for(i = 0; i < 1<<30; i++); printf("The for loop cost %ld.\n", clock() - c); return 0; }
上述程序輸出:
CLOCKS_PER_SEC: 1000 The while loop cost 2234. The for loop cost 2206.
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家學(xué)習(xí)或者使用C語(yǔ)言能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
C語(yǔ)言中fopen()函數(shù)的使用方法示例詳解
這篇文章主要介紹了C語(yǔ)言中fopen()函數(shù)的使用方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06C++實(shí)現(xiàn)簡(jiǎn)單貪吃蛇小游戲
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05深入HRESULT與Windows Error Codes的區(qū)別詳解
本篇文章是對(duì)HRESULT與Windows Error Codes的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)實(shí)戰(zhàn)教學(xué)
在本篇文章里小編給大家分享了關(guān)于C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)實(shí)戰(zhàn)教學(xué)內(nèi)容,有興趣的朋友們可以跟著學(xué)習(xí)參考下。2019-01-01淺析C/C++ 中return *this和return this的區(qū)別
return *this返回的是當(dāng)前對(duì)象的克隆或者本身,return this返回當(dāng)前對(duì)象的地址,下面通過(guò)本文給大家介紹C/C++ 中return *this和return this的區(qū)別,感興趣的朋友一起看看吧2019-10-10C++如何計(jì)算結(jié)構(gòu)體與對(duì)象的大小
這篇文章主要給大家介紹了關(guān)于C++如何計(jì)算結(jié)構(gòu)體與對(duì)象大小的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05C++實(shí)現(xiàn)LeetCode(160.求兩個(gè)鏈表的交點(diǎn))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(160.求兩個(gè)鏈表的交點(diǎn)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07深入探討linux下進(jìn)程的最大線程數(shù)、進(jìn)程最大數(shù)、進(jìn)程打開(kāi)的文件數(shù)
本篇文章是對(duì)linux下進(jìn)程的最大線程數(shù)、進(jìn)程最大數(shù)、進(jìn)程打開(kāi)的文件數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05Linux下g++編譯與使用靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù)的方法
下面小編就為大家?guī)?lái)一篇Linux下g++編譯與使用靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù)的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05