如何将持续时间添加到time_point?

问题描述 投票:3回答:1

我试过这样的事情:

using clock = std::chrono::system_clock;
clock::time_point nowp = clock::now();
clock::time_point end = nowp + std::chrono::seconds(10);
time_t nowt =  clock::to_time_t ( nowp );
time_t endt =  clock::to_time_t ( end);
std::cerr  << " " << ctime(&nowt) << " " << ctime(&endt) << std::endl;

但它打印:

Sat Dec 16 15:06:43 2017
Sat Dec 16 15:06:43 2017

我在这做错了什么?怎么加十秒呢?

c++ chrono
1个回答
4
投票

问题可能是因为ctime存储导致一些静态存储并只返回指向您的指针。

所以它用另一个结果覆盖一个结果并打印2次。操作顺序不是由标准确定的,所以它的作用如下:

  1. 使用一个参数调用ctime,它将表示保存在内部缓冲区中并返回指向它的指针。
  2. 使用另一个参数调用ctime,它将表示保存在同一个内部缓冲区中并返回指向它的指针。
  3. 从两个char *中打印值(实际上是相同的指针)

解决方案是通过将操作与;分开来强制评估顺序

代码fixes problem for me

#include <iostream>
#include <chrono>
using namespace std;


int main() {
    using clock = std::chrono::system_clock;
    clock::time_point nowp = clock::now();
    clock::time_point end = nowp + std::chrono::seconds(10);
    time_t nowt =  clock::to_time_t ( nowp );
    time_t endt =  clock::to_time_t ( end);
    std::cout  << " " << ctime(&nowt) << "\n";
    std::cout << ctime(&endt) << std::endl;
    return 0;
}
© www.soinside.com 2019 - 2024. All rights reserved.