gpt4 book ai didi

c++ - gmtime() 函数是否考虑闰年?

转载 作者:行者123 更新时间:2023-11-28 01:51:11 27 4
gpt4 key购买 nike

我在嵌入式 Linux 上工作,自 1970 年 1 月 1 日起,系统/ Controller 时间以毫秒的形式保持。我正在尝试使用 gmtime 但无法获得准确的结果。将此时间(毫秒)转换为实时小时:分钟:秒:天:月的任何示例都会有所帮助。

最佳答案

你可以使用 civil_from_days这是在 Howard Hinnant 的 chrono-Compatible Low-Level Date Algorithms 中派生和详细解释的.此函数计算自 1/1/1970 以来的天数,并将其转换为 {y, m, d}。 field 。完成后,您只需要处理从毫秒时间戳中减去天数以获得自午夜以来的毫秒数,然后将其分解为 h:M:s.ms。 .

完整代码如下:

#include <iostream>
#include <iomanip>
#include <cstdint>

int
main()
{
using namespace std;
int64_t t = 1490285505123; // milliseconds since epoch
int32_t z = (t >= 0 ? t : t - (1000*86400-1))/(1000*86400); // days since epoch
t -= z * (1000LL * 86400); // milliseconds since midnight
z += 719468;
int32_t era = (z >= 0 ? z : z - 146096) / 146097;
int32_t doe = z - era * 146097;
int32_t yoe = (doe - doe/1460 + doe/36524 - doe/146096) / 365;
int32_t y = yoe + era * 400;
int32_t doy = doe - (365*yoe + yoe/4 - yoe/100);
int32_t m = (5*doy + 2)/153;
int32_t d = doy - (153*m + 2)/5 + 1; // day
m += m < 10 ? 3 : -9; // month
y += m <= 2; // year
int32_t h = t / (1000 * 3600); // hour
t -= h * (1000 * 3600);
int32_t M = t / (1000 * 60); // minute
t -= M * (1000 * 60);
int32_t s = t / 1000; // second
int32_t ms = t - s * 1000; // ms
cout.fill('0');
cout << setw(4) << y << '-' << setw(2) << m << '-' << setw(2) << d
<< ' ' << setw(2) << h << ':' << setw(2) << M
<< ':' << setw(2) << s << '.' << setw(3) << ms << '\n';
}

举个例子,我将 1490285505123ms 用作输入,输出为:

2017-03-23 16:11:45.123

这考虑到了闰年。它不考虑闰秒。您的嵌入式 Linux 系统/ Controller 不太可能同时执行这两种操作,因此尝试这样做是不正确的。

上述算法对t的有效性范围非常大:

-5877641-06-23 00:00:00.000 <= t <= 5880010-09-09 23:59:59.999

(+/- 580 万年)

如果您不介意限制 t 的下限至 0000-03-01 00:00:00.000那么你可以简化 era 的计算到:

int32_t era = z / 146097;

如果可以限制t的下限至 1970-01-01 00:00:00.000然后计算z可以简化为:

int32_t z = t / (1000 * 86400);  // days since epoch

最后,如果你愿意限制t到这 400 年的范围:

2000-03-01 00:00:00.000 <= t <= 2400-02-29 23:59:59.999

然后era可以变得简单:

int32_t const era = 5;

Fwiw,这是一个high-level date/time library利用 C++11/14 <chrono>执行完全相同计算的库,只是语法更清晰。你的 std::lib 必须支持 <chrono>使用这个库:

#include "date.h"
#include <iostream>

int
main()
{
using namespace date;
using namespace std;
using namespace std::chrono;
cout << sys_time<milliseconds>(1490285505123ms) << '\n';
}

关于c++ - gmtime() 函数是否考虑闰年?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42964040/

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