VC++取得系統(tǒng)時(shí)間

字號(hào):


    如果是MFC可以用CTime類(lèi),如果不是就用如下介紹的方法了
    很多情況下我們必須取得系統(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),用法類(lèi)似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)用了。