當我們使用ctime輸出本地當前時間的時候,不知不覺卻對後面的輸出結果產生了影響。即使後面你再使用asctime(gmtime(time_t *))去輸出格林治時間,得到的結果仍爲本地當前時間。
正確的做法是,先輸出格林治時間,再輸出本地當前時間。(假設需要同時輸出當前兩個結果時)
以下是示例代碼:
#include "stdio.h"
#include "time.h"
#include "malloc.h"
#include "limits.h"
int main(int argc, char* argv[])
{
printf("Hello World!/n");
//session 1 : 輸出當前時間和格林治時間,但是結果都會爲當前時間
time_t cor_time;
struct tm *local_time, *UTC_time;
time(&cor_time);//獲取當前時間,是距midnight, January 1, 1970, UTC(格林治時間)計算出的秒
//local_time = localtime(&cor_time);//
UTC_time = gmtime(&cor_time);//將時間轉化成tm結構體,這是按照UTC時間計算出的
printf("session 1:/n");
printf("localtime : %s/n", ctime(&cor_time));//ctime函數會自動將時間轉化成當地時間字符串
//且對後面的時間產生影響
printf("UTC time: %s/n", asctime(UTC_time));//asctime本應輸出真實的格林治時間,但這裏卻輸出本地當前時間
//session 2: 輸出格林治時間和當前時間,時間確實爲格林治時間和當前時間
time_t var_time, var_time_bk;
struct tm *tm_time;
time(&var_time);
tm_time = gmtime(&var_time);
printf("session 2:/n");
printf("UTC time: %s/n", asctime(tm_time));//輸出格林治時間
printf("localtime: %s/n", ctime(&var_time));//輸出當前時間,ctime自動轉化爲本地的時間
//且會對後面的結果產生影響
//conclusion: 當ctime輸出爲當前時間之後,時間會自動轉化爲本地當前時間
//且會對後面的數據產生結果,即使後面使用asctime去輸出格林治時間,輸出的結果仍爲本地當前時間
//所以,如果想同時輸出本地時間和格林治時間,需要先輸出格林治時間,再輸出本地時間
//方能得到真實的結果
return 0;
}