如果是MFC可以用CTime類,如果不是就用如下介紹的方法了
很多情況下我們必須取得系統(tǒng)時(shí)間(像是交作業(yè)…),
但是系統(tǒng)時(shí)間要如何取得呢?
TurboC提供了time(); (被定義在<time.h>中)這個(gè)函式供我們?nèi)〉孟到y(tǒng)時(shí)間,
當(dāng)我們執(zhí)行了time(NULL);時(shí),該函式便會(huì)傳回一個(gè)time_t型態(tài)(被定義在<time.h>中)
的數(shù)字,單位是"秒",所以我們應(yīng)該先用time_t宣告一個(gè)變數(shù),來(lái)接收time()的傳回值:
time_t T; //宣告變數(shù)T為time_t型態(tài)//
T = time(NULL); //變數(shù)T等于time(NULL)的傳回值//
于是變數(shù)T便接收到了一個(gè)單位為"秒"的超大整數(shù),而這個(gè)整數(shù)所代表的意義就是:
從西元1970年1月1日0點(diǎn)0分0秒到目前所經(jīng)過(guò)的秒數(shù),
哇!這不就是我們所要的系統(tǒng)時(shí)間嗎…
但是如果不能換成我們所熟悉的<年/月/日時(shí):分:秒>表示法就沒(méi)意義了。
<如何將系統(tǒng)時(shí)間轉(zhuǎn)成一般表示法>
好不容易取得的系統(tǒng)時(shí)間居然長(zhǎng)這副德性,數(shù)學(xué)好的同學(xué)可能會(huì)想要排除萬(wàn)難,
利用精湛的除法,解決閏年的問(wèn)題,一個(gè)個(gè)將年/月/日/時(shí)/分/秒算出來(lái)…
不過(guò)這樣一來(lái)考試題目可能得帶回家寫(xiě),
TurboC又提供了一個(gè)localtime(); (被定義在<time.h>中)這個(gè)函式就有分割
time_t型態(tài)資料的功能,根據(jù)on-line Help的介紹大致如下:
struct tm * localtime( time_t * );
----------- --------- --------
從這里可以看出localtime需要知道一個(gè)time_t型態(tài)的資料的位址,
然后傳回一個(gè)struct tm結(jié)構(gòu)的資料的位址。
這下問(wèn)題來(lái)了,要告訴localtime() time_t變數(shù)的位址很簡(jiǎn)單,方法如下:
time_t T; //宣告一個(gè)time_t型態(tài)的變數(shù)T //
T = time(NULL); // T =系統(tǒng)時(shí)間//
localtime(&T); //將T的位址&T丟給localtime() //
這樣就好了,但是struct tm到底是什么呢?
(struct就是結(jié)構(gòu),用法類似class但無(wú)Member function )
在on-line Help中看到tm的介紹如下:
<TIME.H> //被<time.h>定義//
struct tm {
int tm_sec; /*秒(0--59) */
int tm_min; /*分(0--59) */
int tm_hour; /*時(shí)(0--23) */
int tm_mday; /*日of month (1--31) */
int tm_mon; /*月(0--11記得自己+ 1) */
int tm_year; /*年(要把這個(gè)值+1900才是西元年紀(jì)喔) */
int tm_wday; /*日of Week (0--6; Sunday = 0) */
int tm_yday; /*日of year (0--365) */
int tm_isdst; /* 0 if daylight savings time is not in effect) */
};
看到這個(gè)就大概可以知道, localtime()先將我們給的time_t資料換算成
年/月/日/時(shí)/分/秒,然后依照結(jié)構(gòu)tm的順序放在記憶體中,
并將該記憶體位址傳回。
原來(lái)如此,那我們不就只要宣告一個(gè)tm型態(tài)的指標(biāo),然后將該指標(biāo)指向
localtime()的傳回值,然后再讀取該指標(biāo)的內(nèi)容就好啦^^馬上試試:
#include<time.h>
#include<iostream.h>
void main(void)
{
int year, mon, day; //要用來(lái)存日期的//
int hour, min, sec; //要用來(lái)存時(shí)間的//
time_t T; //要用來(lái)存系統(tǒng)時(shí)間的//
struct tm *TimeP; //要用來(lái)指到localtime()傳回的位址的//
T = time(NULL); //將系統(tǒng)時(shí)間存到T //
TimeP = localtime( &T ); // TimeP指到localtime算好的資料所在位址//
//接下來(lái)就來(lái)看TimeP所指到的地方放了什么^^ //
year = ( TimeP->tm_year ) + 1900;
mon = ( TimeP->tm_mon ) + 1;
day = ( TimeP->tm_mday );
hour = ( TimeP->tm_hour );
min = ( TimeP->tm_min );
sec = ( TimeP->tm_sec );
cout 《 year 《 "/" 《 mon 《 "/" 《 day 《 endl;
cout 《 hour 《 ":" 《 min 《 ":" 《 sec 《 endl;
}
結(jié)果果然localtime()已經(jīng)幫我們把T的資料換算好了(感動(dòng)~~),
而我們從TimeP指出去的各成員也都傳回正確的數(shù)據(jù),連日期都沒(méi)問(wèn)題^^
總之,我們已經(jīng)學(xué)會(huì)如何取得系統(tǒng)時(shí)間了,
剩下的就看各位要如何運(yùn)用了。
更多信息請(qǐng)查看IT技術(shù)專欄