Другие отметили, что конкретная дата, которую вы приводите в качестве примера, выходит за пределы максимальной даты / времени, представляемой 32-битным time_t, часто называемым проблемой Year 2038 . Одним из решений является использование 64-битного time_t, что делают некоторые 64-битные системы POSIX (linux amd64), и вызов mktime
.
#include <time.h>
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
struct tm future; /* as in future date */
time_t t;
future.tm_sec = 0;
future.tm_min = 0;
future.tm_hour = 0;
future.tm_mday = 1; /* 1st */
future.tm_mon = 6; /* July */
future.tm_year = 2038 - 1900; /* 2038 in years since 1900 */
future.tm_isdst = 0; /* Daylight Saving not in affect (UTC) */
#ifdef _BSD_SOURCE
future.tm_zone = "UTC";
#endif
t = mktime( &future );
if ( -1 == t ) {
printf("Error converting 1 July 2038 to time_t time since Epoch\n");
return EXIT_FAILURE;
}
printf("UTC time and date: %s\n", asctime( &future ) );
return EXIT_SUCCESS;
}