mktime:意外的结果

时间:2016-02-20 11:42:29

标签: c tm mktime

我想在struct tm中使用time_tmktime转换为c
这是我的代码:

#include <stdio.h>
#include <time.h>

int main(int argc, char **argv)
{
struct tm _tm;
time_t _t;

  strptime ("20160220", "%Y%m%d", &_tm);
  printf ("1: struct tm => %04d%02d%02d\n", _tm.tm_year+1900
                                          , _tm.tm_mon+1
                                          , _tm.tm_mday);

  _t = mktime(&_tm);
  printf ("2: struct tm => %04d%02d%02d | time_t: %lu\n"
                                                  , _tm.tm_year+1900
                                                  , _tm.tm_mon+1
                                                  , _tm.tm_mday
                                                  , _t);

  _tm = *(localtime(&_t));
  printf ("3: struct tm => %04d%02d%02d | time_t: %lu\n"
                                                  , _tm.tm_year+1900
                                                  , _tm.tm_mon+1
                                                  , _tm.tm_mday
                                                  , _t);
  return 0;
}

但它给了我一个意想不到的输出:

1: struct tm => 20160220
2: struct tm => 24941121 | time_t: 16563985201
3: struct tm => 24941121 | time_t: 16563985201

显然_tm的价值在mktime中发生变化,并且返回的值不正确。
我做错了什么? 我在gcc版本4.9.2

的Linux系统上编译它(64位)

1 个答案:

答案 0 :(得分:2)

您有未定义的行为,因为_tm未正确初始化。

函数strptime只会设置格式字符串中指定的成员,其他函数将保持不变,因此它们的值将是不确定的。

然后函数mktime将修复不在范围内的值,从而为您提供截然不同的时间,因为_tm中未初始化的成员值。

解决方案是正确初始化:

struct tm _tm = { 0 };

(并且不要在名称中使用前缀_,因为它由C保留。