小心小心C语言时间函数陷阱语言时间函数陷阱
在编写C语言的应用程序时,为了获取或者打印一些跟时间有关的信息,我们经常会使用到C语言自带的一 些时
间函数,诸如:time、localtime、ctime、mktime和asctime等。但你可能没有注意到这里面含有一些有 趣的现
象。
先来看一个例子:
1 #include <stdio.h>
2 #include <time.h>
3
4 int main ()
5 {
6
7 time_t time_1, time_2;
8 struct tm *tm_1, *tm_2, *tm_3;
9 struct tm tm_4, tm_5;
10
11 printf("-------------------- PART I -------------------");
12
13 time_1 = time(NULL);
14 sleep(3);
15 time_2 = time(NULL);
16 printf("time1:%d time2:%d",time_1,time_2);
17
18 tm_1 = (struct tm*)localtime(&time_1);
19 tm_2 = (struct tm*)localtime(&time_2);
20 tm_3 = (struct tm*)localtime(&time_1);
21
22 printf("tm_1 ptr:%p tm_2 ptr:%p tm_3 ptr:%p",tm_1,tm_2,tm_3);
23 printf("asctime(tm_1):%s",asctime(tm_1));
24 printf("asctime(tm_2):%s",asctime(tm_2));
25 printf("asctime(tm_3):%s",asctime(tm_3));
26 }
在看这段代码的输出结果之前,先问大家两个问题:
(1) 第22行,struct tm结构体 tm_1、tm_2 和tm_3的值有什么关系?
(2) 第23-26行的输出结果中,tm_2的时间真的比tm_1晚3秒吗?
接下来 ,我们来看一下这段代码的输出结果:
-------------------- PART I -------------------
time1:1340256774 time2:1340256777