井蛙夏虫 发表于 2013-04-30 13:16

gmtime时间转换结果错误

我的测试程序的流程:
1.构造一个tm结构 --> mktime --> gmtime_r;
2.构造一个tm结构 --> mktime --> localtime_r;

问题:
对于第一种情况,当设置的时间比较早时,除了8小时的时区差外,结果还会产生5分52秒的时间差距;当比较晚时,结果是正确的。分界线大约在1927-1928之间。比如将tm结构填为1917-2-1-00:00:00时,结果的tm结构时间为1917-1-31-15:54:08.
第二种情况总是正确的。

系统环境:
32位fedora16系统
时区设置为CST
gcc-4.6.3-2
glibc-2.14.90-24

望高手解答,谢谢!

linux_c_py_php 发表于 2013-05-01 14:20

mktime是把tm专成time_t, 然后按照时区把time_t偏移回UTC.

gmtime是给定UTC, 直接生成tm.
localtim是给定UTC, 先按照时区把time_t偏移到本地时间, 然后转tm.

理解这些, 如果还能算错, 那基本说明你的系统时区配的不对, 也不排除类似夏时令之类概念的影响, 那些我就不懂了.

井蛙夏虫 发表于 2013-05-02 15:49

谢谢楼上的回答。我已经知道原因了。
见http://www.timeanddate.com/worldclock/clockchange.html?n=237&year=1927。
或者在命令行运行"zdump -v 'Asia/Shanghai'"(如果你配置的时区是Asia/Shanghai,可以直接运行"zdump -v /etc/localtime")。
这是历史原因。
页: [1]
查看完整版本: gmtime时间转换结果错误