C ++无法比较两个具有相同持续时间的std :: chrono :: time_points

时间:2015-07-06 22:39:25

标签: c++ c++11 chrono

我正在尝试将std::chrono::time_point转换为长变量,然后转换回std::chrono::time_point类。 long变量将用于在我的架构上发送客户端/服务器消息。

所以我有以下测试代码(代码here):

int main ()
{
    std::chrono::time_point<std::chrono::system_clock> now = std::chrono::system_clock::now();

    auto epoch = now.time_since_epoch();
    auto value = std::chrono::duration_cast<std::chrono::milliseconds>(epoch);
    long duration = value.count();

    std::cout << "Duration=" << duration << std::endl;  

    std::chrono::milliseconds ms(duration);

    std::chrono::time_point<std::chrono::system_clock> dt(ms);

    auto epoch1 = dt.time_since_epoch();
    auto value1 = std::chrono::duration_cast<std::chrono::milliseconds>(epoch1);
    long duration1 = value1.count();
    std::cout << "Duration1=" << duration1 << std::endl;  

    if (dt != now)
        std::cout << "Failure." << std::endl;
    else
        std::cout << "Success." << std::endl;
}

从输出结果来看,我有:

Duration=1436221951916
Duration1=1436221951916
Failure.

为什么两个持续时间都相同,但两次都不一样(比较Failure)?我在这里缺少什么?

帮助表示赞赏。

1 个答案:

答案 0 :(得分:3)

您从std::chrono::time_pointlong的转换将时间点转换为毫秒。

请参阅this question on how properly serialize and deserialize time_points