time_t 時間型別詳解 (time_t屬於C++函式)
阿新 • • 發佈:2019-01-27
下載: gettime5.c
/*gettime5.c*/
#include <time.h>
int main()
{
time_t timep;
struct tm *p;
time(&timep); /*當前time_t型別UTC時間*/
printf("time():%d\n",timep);
p = localtime(&timep); /*轉換為本地的tm結構的時間按*/
timep = mktime(p); /*重新轉換為time_t型別的UTC時間,這裡有一個時區的轉換*/ //by lizp 錯誤,沒有時區轉換, 將struct tm 結構的時間 轉換為從1970年至p的秒數
printf("time()->localtime()->mktime(): %d\n", timep);
return 0;
}
編譯並執行:
$gcc -o gettime5 gettime5.c
$./gettime5
time():1200074913
time()->localtime()->mktime(): 1200074913
這裡面把UTC時間按轉換為本地時間,然後再把本地時間轉換為UTC時間,它們轉換的結果保持一致。
下載: gettime6.c
/*gettime6.c */
#include <time.h>
int main()
{
time_t timep;
struct tm *p;
time(&timep); /*得到time_t型別的UTC時間*/
printf("time():%d\n",timep);
p = gmtime(&timep); /*得到tm結構的UTC時間*/
timep = mktime(p); /*轉換,這裡會有時區的轉換*/ //by lizp 錯誤,沒有時區轉換, 將struct tm 結構的時間 轉換為從1970年至p的秒數
printf("time()->gmtime()->mktime(): %d\n", timep);
return 0;
}
編譯並執行:
$gcc -o gettime6 gettime6.c
$./gettime6
time():1200075192
time()->gmtime()->mktime(): 1200046392
從這裡面我們可以看出,轉換後時間不一致了,計算一下,整整差了8個小時( (1200075192-1200046392)/3600 = 8),說明mktime會把本地時間轉換為UTC時間,這裡面本來就是UTC時間,於是再弄個時區轉換,結果差了8個小時,用的時候應該注意。
strftime() 函式將時間格式化
我們可以使用strftime()函式將時間格式化為我們想要的格式。它的原型如下:
size_t strftime(
char *strDest,
size_t maxsize,
const char *format,
const struct tm *timeptr
);
我們可以根據format指向字串中格式命令把timeptr中儲存的時間 資訊放在strDest指向的字串中,最多向strDest中存放maxsize個字元。該函式返回向strDest指向的字串中放置的字元數。
函式strftime()的操作有些類似於sprintf():識別以百分號(%)開始的格式命令集合,格式化輸出結果放在一個字串中。格式化命令說明串 strDest中各種日期和時間資訊的確切表示方法。格式串中的其他字元原樣放進串中。格式命令列在下面,它們是區分大小寫的。
%a 星期幾的簡寫
%A 星期幾的全稱
%b 月分的簡寫
%B 月份的全稱
%c 標準的日期的時間串
%C 年份的後兩位數字
%d 十進位制表示的每月的第幾天
%D 月/天/年
%e 在兩字元域中,十進位制表示的每月的第幾天
%F 年-月-日
%g 年份的後兩位數字,使用基於周的年
%G 年分,使用基於周的年
%h 簡寫的月份名
%H 24小時制的小時
%I 12小時制的小時
%j 十進位制表示的每年的第幾天
%m 十進位制表示的月份
%M 十時製表示的分鐘數
%n 新行符
%p 本地的AM或PM的等價顯示
%r 12小時的時間
%R 顯示小時和分鐘:hh:mm
%S 十進位制的秒數
%t 水平製表符
%T 顯示時分秒:hh:mm:ss
%u 每週的第幾天,星期一為第一天 (值從0到6,星期一為0)
%U 第年的第幾周,把星期日做為第一天(值從0到53)
%V 每年的第幾周,使用基於周的年
%w 十進位制表示的星期幾(值從0到6,星期天為0)
%W 每年的第幾周,把星期一做為第一天(值從0到53)
%x 標準的日期串
%X 標準的時間串
%y 不帶世紀的十進位制年份(值從0到99)
%Y 帶世紀部分的十制年份
%z,%Z 時區名稱,如果不能得到時區名稱則返回空字元。
%% 百分號
如果想顯示現在是幾點了,並以12小時制顯示,就象下面這段程式:
#include "time.h"
#include "stdio.h"
int main(void)
{
struct tm *ptr;
time_t lt;
char str[80];
lt=time(NULL);
ptr=localtime(<);
strftime(str,100,"It is now %I %p",ptr);
printf(str);
return 0;
}
其執行結果為:
It is now 4PM
而下面的程式則顯示當前的完整日期:
#include<stdio.h>
#include<string.h>
#include<time.h>
int main( void )
{
struct tm *newtime;
char tmpbuf[128];
time_t lt1;
time( <1 );
newtime=localtime(<1);
strftime( tmpbuf, 128, "Today is %A, day %d of %B in the year %Y.\n", newtime);
printf(tmpbuf);
return 0;
}
/*gettime5.c*/
#include <time.h>
int main()
{
time_t timep;
struct tm *p;
time(&timep); /*當前time_t型別UTC時間*/
printf("time():%d\n",timep);
p = localtime(&timep); /*轉換為本地的tm結構的時間按*/
timep = mktime(p); /*重新轉換為time_t型別的UTC時間,這裡有一個時區的轉換*/ //by lizp 錯誤,沒有時區轉換, 將struct tm 結構的時間
printf("time()->localtime()->mktime(): %d\n", timep);
return 0;
}
編譯並執行:
$gcc -o gettime5 gettime5.c
$./gettime5
time():1200074913
time()->localtime()->mktime(): 1200074913
這裡面把UTC時間按轉換為本地時間,然後再把本地時間轉換為UTC時間,它們轉換的結果保持一致。
下載: gettime6.c
/*gettime6.c */
#include <time.h>
int main()
{
time_t timep;
struct tm *p;
time(&timep); /*得到time_t型別的UTC時間*/
printf("time():%d\n",timep);
p = gmtime(&timep); /*得到tm結構的UTC時間*/
timep = mktime(p); /*轉換,這裡會有時區的轉換*/ //by lizp 錯誤,沒有時區轉換, 將struct tm 結構的時間
printf("time()->gmtime()->mktime(): %d\n", timep);
return 0;
}
編譯並執行:
$gcc -o gettime6 gettime6.c
$./gettime6
time():1200075192
time()->gmtime()->mktime(): 1200046392
從這裡面我們可以看出,轉換後時間不一致了,計算一下,整整差了8個小時( (1200075192-1200046392)/3600 = 8),說明mktime會把本地時間轉換為UTC時間,這裡面本來就是UTC時間,於是再弄個時區轉換,結果差了8個小時,用的時候應該注意。
strftime() 函式將時間格式化
我們可以使用strftime()函式將時間格式化為我們想要的格式。它的原型如下:
size_t strftime(
char *strDest,
size_t maxsize,
const char *format,
const struct tm *timeptr
);
我們可以根據format指向字串中格式命令把timeptr中儲存的時間
函式strftime()的操作有些類似於sprintf():識別以百分號(%)開始的格式命令集合,格式化輸出結果放在一個字串中。格式化命令說明串 strDest中各種日期和時間資訊的確切表示方法。格式串中的其他字元原樣放進串中。格式命令列在下面,它們是區分大小寫的。
%a 星期幾的簡寫
%A 星期幾的全稱
%b 月分的簡寫
%B 月份的全稱
%c 標準的日期的時間串
%C 年份的後兩位數字
%d 十進位制表示的每月的第幾天
%D 月/天/年
%e 在兩字元域中,十進位制表示的每月的第幾天
%F 年-月-日
%g 年份的後兩位數字,使用基於周的年
%G 年分,使用基於周的年
%h 簡寫的月份名
%H 24小時制的小時
%I 12小時制的小時
%j 十進位制表示的每年的第幾天
%m 十進位制表示的月份
%M 十時製表示的分鐘數
%n 新行符
%p 本地的AM或PM的等價顯示
%r 12小時的時間
%R 顯示小時和分鐘:hh:mm
%S 十進位制的秒數
%t 水平製表符
%T 顯示時分秒:hh:mm:ss
%u 每週的第幾天,星期一為第一天 (值從0到6,星期一為0)
%U 第年的第幾周,把星期日做為第一天(值從0到53)
%V 每年的第幾周,使用基於周的年
%w 十進位制表示的星期幾(值從0到6,星期天為0)
%W 每年的第幾周,把星期一做為第一天(值從0到53)
%x 標準的日期串
%X 標準的時間串
%y 不帶世紀的十進位制年份(值從0到99)
%Y 帶世紀部分的十制年份
%z,%Z 時區名稱,如果不能得到時區名稱則返回空字元。
%% 百分號
如果想顯示現在是幾點了,並以12小時制顯示,就象下面這段程式:
#include "time.h"
#include "stdio.h"
int main(void)
{
struct tm *ptr;
time_t lt;
char str[80];
lt=time(NULL);
ptr=localtime(<);
strftime(str,100,"It is now %I %p",ptr);
printf(str);
return 0;
}
其執行結果為:
It is now 4PM
而下面的程式則顯示當前的完整日期:
#include<stdio.h>
#include<string.h>
#include<time.h>
int main( void )
{
struct tm *newtime;
char tmpbuf[128];
time_t lt1;
time( <1 );
newtime=localtime(<1);
strftime( tmpbuf, 128, "Today is %A, day %d of %B in the year %Y.\n", newtime);
printf(tmpbuf);
return 0;
}