Linux-x64 glibc: Почему 1 февраля выйдет до 31 января?

Когда вы вызываете mktime(), 1 февраля, похоже, до 31 января. Почему? Я делаю что-то неправильно или это ошибка в glibc?

Здесь код:

struct tm tm;
time_t tt;

memset(&tm, 0, sizeof(tm));
tm.tm_year = 2011;
tm.tm_mon = 1;
tm.tm_mday = 31;
tm.tm_hour = 11;
tm.tm_min = 41;
tm.tm_sec = 28;
tm.tm_isdst = 0;
tt = mktime(&tm);

printf("Time now %d-%d-%d %d:%d:%d (%s) = %lu\n",
    tm.tm_year, tm.tm_mon, tm.tm_mday, tm.tm_hour, tm.tm_min, tm.tm_sec, tm.tm_zone, tt);


memset(&tm, 0, sizeof(tm));
tm.tm_year = 2011;
tm.tm_mon = 2;
tm.tm_mday = 1;
tm.tm_hour = 1;
tm.tm_min = 1;
tm.tm_sec = 1;
tm.tm_isdst = 0;
tt = mktime(&tm);

printf("Time now %d-%d-%d %d:%d:%d (%s) = %lu\n",
    tm.tm_year, tm.tm_mon, tm.tm_mday, tm.tm_hour, tm.tm_min, tm.tm_sec, tm.tm_zone, tt);

И вот вывод:

Time now 2011-2-3 11:41:28 (PST) = 61257325288
Time now 2011-2-1 1:1:1 (PST) = 61257114061

Обратите внимание, что первоначальное намерение состояло в том, чтобы сравнить два time_t. Эта проблема приводит к тому, что первая дата/время будет отображаться позже второй, что, очевидно, является проблемой.

Это просто скомпилировано с помощью "gcc test.c" и запускается с "./a.out" на Ubuntu 9.10, gcc версии 4.4.1 (Ubuntu 4.4.1-4ubuntu8), libc-2.10.1-0ubuntu15

В 32-битной системе результаты ожидаются, т.е. полностью отличаются от результата 64 бит!

Кто-нибудь хотел бы подтвердить/опровергнуть этот результат и/или дать некоторое представление о том, что я могу делать неправильно?

Ответ 1

tm_mon основано на нуле, поэтому вы попытались установить 31-го февраля, который получил нормализацию. Здесь ссылка на определение mktime().