前言
在標准C中, 日期和時間的處理包含在 time.h 的頭文件中。
需要使用日期和時間相關的類型的函數的話, 需要導入time.h.
本篇介紹的部分有:
1. 日期時間相關的類型
2. 日期時間相關的函數
3. 一些例子
日期時間相關的數據類型
1. time_t
time_t是一個長整型數。表示的時間(日歷時間)是從一個時間點(例如:1970年1月1日0時0分0秒)到此時的秒數。
這個類型的值類似:
9.73E+08
2. tm
結構體類型。 可以在time.h 中看到定義如下:
struct tm { int tm_sec; /* seconds after the minute - [0,59] */ int tm_min; /* minutes after the hour - [0,59] */ int tm_hour; /* hours since midnight - [0,23] */ int tm_mday; /* day of the month - [1,31] */ int tm_mon; /* months since January - [0,11] */ int tm_year; /* years since 1900 */ int tm_wday; /* days since Sunday - [0,6] */ int tm_yday; /* days since January 1 - [0,365] */ int tm_isdst; /* daylight savings time flag */ }; struct tm { int tm_sec; /* seconds after the minute - [0,59] */ int tm_min; /* minutes after the hour - [0,59] */ int tm_hour; /* hours since midnight - [0,23] */ int tm_mday; /* day of the month - [1,31] */ int tm_mon; /* months since January - [0,11] */ int tm_year; /* years since 1900 */ int tm_wday; /* days since Sunday - [0,6] */ int tm_yday; /* days since January 1 - [0,365] */ int tm_isdst; /* daylight savings time flag */ };
3. timeval
日期時間相關的函數
1. time(取得目前的時間)
time_t time(time_t *t);
函數說明: 此函數會返回從公元1970年1月1日的UTC時間從0時0分0秒算起到現在所經過的秒數。如果t 並非空指針的話,此函數也會將返回值存到t指針所指的內存。
2. asctime(將時間和日期以字符串格式表示)
相關函數:time,ctime,gmtime,localtime
表頭文件:#include<time.h>
定義函數:char * asctime(const struct tm * timeptr);
函數說明:asctime()將參數timeptr所指的tm結構中的信息轉換成真實世界所使用的時間日期表示方法,
然後將結果以字符串形態返回。此函數已經由時區轉換成當地時間,
字符串格式為:“Wed Jun 30 21:49:08 1993\n”
返 回 值:若再調用相關的時間日期函數,此字符串可能會被破壞。
此函數與ctime不同處在於傳入的參數是不同的結構。
附加說明:返回一字符串表示目前當地的時間日期。
范 例:
1#include <time.h>
2main() {
3 time_t timep;
4 time (&timep);
5 printf(“%s”,asctime(gmtime(&timep)));
6}
執行結果:Sat Oct 28 02:10:06 2000
3. ctime(將時間和日期以字符串格式表示)
相關函數:time,asctime,gmtime,localtime
表頭文件:#include<time.h>
定義函數:char *ctime(const time_t *timep);
函數說明:ctime()將參數timep所指的time_t結構中的信息轉換成真實世界所使用的時間日期表示方法,
然後將結果以字符串形態返回。此函數已經由時區轉換成當地時間,
字符串格式為“Wed Jun 30 21 :49 :08 1993\n”。
若再調用相關的時間日期函數,此字符串可能會被破壞。
返 回 值:返回一字符串表示目前當地的時間日期。
范 例:
1#include<time.h>
2main(){
3 time_t timep;
4 time (&timep);
5 printf(“%s”,ctime(&timep));
6}
執行結果:Sat Oct 28 10 : 12 : 05 2000
4. gettimeofday(取得目前的時間)
相關函數:time,ctime,ftime,settimeofday
表頭文件:#include <sys/time.h>
#include <unistd.h>
定義函數:int gettimeofday ( struct timeval * tv , struct timezone * tz )
函數說明:gettimeofday()會把目前的時間有tv所指的結構返回,當地時區的信息則放到tz所指的結構中。
timeval結構定義為:
1struct timeval{
2 long tv_sec; /*秒*/
3 long tv_usec; /*微秒*/
4};
timezone 結構定義為:
1struct timezone{
2 int tz_minuteswest; /*和Greenwich 時間差了多少分鐘*/
3 int tz_dsttime; /*日光節約時間的狀態*/
4};
上述兩個結構都定義在/usr/include/sys/time.h。tz_dsttime 所代表的狀態如下
DST_NONE /*不使用*/
DST_USA /*美國*/
DST_AUST /*澳洲*/
DST_WET /*西歐*/
DST_MET /*中歐*/
DST_EET /*東歐*/
DST_CAN /*加拿大*/
DST_GB /*大不列顛*/
DST_RUM /*羅馬尼亞*/
DST_TUR /*土耳其*/
DST_AUSTALT /*澳洲(1986年以後)*/
返 回 值:成功則返回0,失敗返回-1,錯誤代碼存於errno。
附加說明EFAULT指針tv和tz所指的內存空間超出存取權限。
范 例:
1#include<sys/time.h>
2#include<unistd.h>
3main(){
4 struct timeval tv;
5 struct timezone tz;
6 gettimeofday (&tv , &tz);
7 printf(“tv_sec; %d\n”, tv,.tv_sec) ;
8 printf(“tv_usec; %d\n”,tv.tv_usec);
9 printf(“tz_minuteswest; %d\n”, tz.tz_minuteswest);
10 printf(“tz_dsttime, %d\n”,tz.tz_dsttime);
11}
執行結果:
tv_sec: 974857339
tv_usec:136996
tz_minuteswest:-540
tz_dsttime:0
5. gmtime(取得目前時間和日期)
相關函數:time,asctime,ctime,localtime
表頭文件:#include<time.h>
定義函數:struct tm*gmtime(const time_t*timep);
函數說明:gmtime()將參數timep 所指的time_t 結構中的信息轉換成真實世界所使用的時間日期表示方法,
然後將結果由結構tm返回。
int tm_sec 代表目前秒數,正常范圍為0-59,但允許至61秒
int tm_min 代表目前分數,范圍0-59
int tm_hour 從午夜算起的時數,范圍為0-23
int tm_mday 目前月份的日數,范圍01-31
int tm_mon 代表目前月份,從一月算起,范圍從0-11
int tm_year 從1900 年算起至今的年數
int tm_wday 一星期的日數,從星期一算起,范圍為0-6
int tm_yday 從今年1月1日算起至今的天數,范圍為0-365
int tm_isdst 日光節約時間的旗標
此函數返回的時間日期未經時區轉換,而是UTC時間。
返 回 值:返回結構tm代表目前UTC 時間
范 例:
1#include <time.h>
2main(){
3 char *wday[]={"Sun","Mon","Tue","Wed","Thu","Fri","Sat"};
4 time_t timep;
5 struct tm *p;
6 time(&timep);
7 p=gmtime(&timep);
8 printf(“%d%d%d”,(1900+p->tm_year), (1+p->tm_mon),p->tm_mday);
9 printf(“%s%d;%d;%d\n”, wday[p->tm_wday], p->tm_hour, p->tm_min, p->tm_sec);
10}
執行結果:2000/10/28 Sat 8:15:38
6. localtime(取得當地目前時間和日期)
相關函數:time, asctime, ctime, gmtime
表頭文件:#include<time.h>
定義函數:struct tm *localtime(const time_t * timep);
函數說明:localtime()將參數timep所指的time_t結構中的信息轉換成真實世界所使用的時間日期表示方法,
然後將結果由結構tm返回。結構tm的定義請參考gmtime()。
此函數返回的時間日期已經轉換成當地時區。
返 回 值:返回結構tm代表目前的當地時間。
范 例:
1#include<time.h>
2main(){
3 char *wday[]={“Sun”,”Mon”,”Tue”,”Wed”,”Thu”,”Fri”,”Sat”};
4 time_t timep;
5 struct tm *p;
6 time(&timep);
7 p=localtime(&timep); /*取得當地時間*/
8 printf (“%d%d%d ”, (1900+p->tm_year),( l+p->tm_mon), p->tm_mday);
9 printf(“%s%d:%d:%d\n”, wday[p->tm_wday],p->tm_hour, p->tm_min, p->tm_sec);
10}
執行結果:2000/10/28 Sat 11:12:22
7. mktime(將時間結構數據轉換成經過的秒數)
相關函數:time,asctime,gmtime,localtime
表頭文件:#include<time.h>
定義函數:time_t mktime(strcut tm * timeptr);
函數說明:mktime()用來將參數timeptr所指的tm結構數據轉換成
從公元1970年1月1日0時0分0 秒算起至今的UTC時間所經過的秒數。
返 回 值:返回經過的秒數。
范 例:
1/* 用time()取得時間(秒數),利用localtime()
2轉換成struct tm 再利用mktine()將struct tm轉換成原來的秒數*/
3#include<time.h>
4main() {
5 time_t timep;
6 strcut tm *p;
7 time(&timep);
8 printf(“time() : %d \n”,timep);
9 p=localtime(&timep);
10 timep = mktime(p);
11 printf(“time()->localtime()->mktime():%d\n”,timep);
12}
執行結果:time():974943297
time()->localtime()->mktime():974943297
8. settimeofday(設置目前時間)
相關函數:time,ctime,ftime,gettimeofday
表頭文件:#include<sys/time.h>
#include<unistd.h>
定義函數:int settimeofday ( const struct timeval *tv,const struct timezone *tz);
函數說明:settimeofday()會把目前時間設成由tv所指的結構信息,當地時區信息則設成tz所指的結構。
詳細的說明請參考gettimeofday()。注意,只有root權限才能使用此函數修改時間。
返 回 值:成功則返回0,失敗返回-1,錯誤代碼存於errno。
錯誤代碼:EPERM 並非由root權限調用settimeofday(),權限不夠。
EINVAL 時區或某個數據是不正確的,無法正確設置時間。