boost :: date_time(boost-145)使用带有microsec计算的64位uint,没有截断

Has*_*yed 5 c++ datetime boost

我正在使用date_time来抽象出平台的特殊性.我需要生成一个64位的microsec分辨率uint64_t,它将用于序列化.我不明白下面出了什么问题.

#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/cstdint.hpp>
#include <iostream>

using namespace boost::posix_time;
using boost::uint64_t;

ptime UNIX_EPOCH(boost::gregorian::date(1970,1,1));

int main() {
    ptime current_time = microsec_clock::universal_time();

    std::cout << "original time: "<< current_time << std::endl;

    long microsec_since_epoch = ((current_time -UNIX_EPOCH).total_microseconds());

    ptime output_ptime = UNIX_EPOCH + microseconds(microsec_since_epoch);
        std::cout << "Deserialized time : " << output_ptime << std::endl;

    std::cout << "Microsecond output: " << microsec_since_epoch << std::endl;

    std::cout << "Microsecond to second arithmetic: "
        << microsec_since_epoch/(10*10*10*10*10*10) << std::endl;

    std::cout << "Microsecond to tiume_duration, back to microsecond : " <<
        microseconds(microsec_since_epoch).total_microseconds() << std::endl;


    return 0;
}
Run Code Online (Sandbox Code Playgroud)

这是我得到的输出.

original time: 2010-Dec-17 09:52:06.737123
Deserialized time : 1970-Jan-16 03:10:41.577454
Microsecond output: 1292579526737123
Microsecond to second arithmetic: 1292579526
Microsecond to tiume_duration, back to microsecond : 1307441577454
Run Code Online (Sandbox Code Playgroud)

当我切换到使用total_seconds()和+ seconds(..)问题dissapear --ie时,输入更改为:

2010-Dec-15 18:26:22.606978
2010-Dec-15 18:26:22
Run Code Online (Sandbox Code Playgroud)

date_time声称在内部使用64位类型,2^64÷ (10^6×3600×24×365) ~= 584942甚至是2^60÷ (10^6×3600×24×365) ~= 36558.

来自维基百科的开场词有关于Posix时间的说法

Unix时间或POSIX时间是用于描述时间点的系统,定义为自1970年1月1日午夜协调世界时(UTC)以来经过的秒数

为什么如此大规模的截断将持续40年?

如何使用boost :: date_time以微秒级分辨率使用完整的64位空间?

-edit1回应汉斯 -

帖子已更改为反映duration.total_microseconds()部分的整数输出.注1292576572566904÷(10 ^ 6×3600×24×365)〜= 40.98年.秒的输出尚未更新.

--edit2-- 在"反序列化"步骤之前将微秒缩小到几秒,也很有效.这种方法解决了我的问题,我只需要在创建时使用微秒分辨率,并且在反序列化时我可以不使用它.

我仍然想知道问题的原因和原因.

Has*_*yed 2

这似乎是 microseconds() 无法处理如此大的微秒输入的问题。以下代码片段是对此问题的修复:

#define MICROSEC 1000000

uint64_t sec_epoch = microsec_since_epoch / MICROSEC;
uint64_t mod_micro_epoch= microsec_since_epoch % MICROSEC;

ptime new_method = UNIX_EPOCH  + seconds(sec_epoch) + microseconds(mod_micro_epoch);

std::cout << "Deserialization with new method: " << new_method << std::endl;
Run Code Online (Sandbox Code Playgroud)