gpt4 book ai didi

c++ - 使用 C++ 计算两个日期的差异

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:57:03 29 4
gpt4 key购买 nike

我试图通过首先读取本地时间保存 tm 结构并休眠 5 秒然后读取另一个本地时间并保存到另一个 tm 结构来获取两个日期的差异。我希望一旦我将两个日期的差异得到 5 或更大的值。但是,我得到 0。

如果注释掉以下行,我会得到正确的结果:

  oldyear.tm_year = oldyear.tm_year + 1900;
oldyear.tm_mon = oldyear.tm_mon + 1;


newyear.tm_year = newyear.tm_year + 1900;
newyear.tm_mon = newyear.tm_mon + 1;

我的代码:

void timeTest()
{

time_t now;
struct tm newyear, oldyear;
double seconds;

time(&now); /* get current time; same as: now = time(NULL) */
oldyear = *localtime(&now);
oldyear.tm_year = oldyear.tm_year + 1900;
oldyear.tm_mon = oldyear.tm_mon + 1;

int epoch1 = mktime(&oldyear);
sleep(5);
time(&now); /* get current time; same as: now = time(NULL) */

newyear = *localtime(&now);
newyear.tm_year = newyear.tm_year + 1900;
newyear.tm_mon = newyear.tm_mon + 1;

int epoch2 = mktime(&newyear);

seconds = difftime(mktime(&newyear),mktime(&oldyear));

printf ("%.f seconds since new year in the current timezone.\n", seconds);
}

最佳答案

如果我在 64 位系统 Linux 上编译它,我会得到输出

5 seconds since new year in the current timezone.

但是,如果我为 32 位系统编译,

% gcc -m32 test2.c
% ./a.out
0 seconds since new year in the current timezone.

请注意,mktime 预计年份是从 1900 年开始,月份是从 0 开始,因此您所做的调整是不正确的,并且可能会导致 32 位计算机上的溢出。您的代码所做的是计算日期 3914-08-28 上 2 个时间点的差异 - 在 32 位系统上,time_t 通常是 32 位,并且最大代表的日期是03:14:07 UTC on Tuesday, 19 January 2038使用又名 Y2K38 jf 签名 time_t

错误返回-1:

If the specified broken-down time cannot be represented as calendar time (seconds since the Epoch), mktime() returns (time_t) -1 and does not alter the members of the broken-down time structure.

因此,如果您打印出 epochepoch2,我敢打赌您会得到这两个时间戳的 -1

关于c++ - 使用 C++ 计算两个日期的差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24989107/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com