当我们使用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;
}