我试过这样的事情:
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
我在这里做错了什么?怎么加10秒呢?
答案 0 :(得分:4)
问题可能是因为ctime
存储了一些静态存储,只是将指针返回给你。
所以它用另一个结果覆盖一个结果并打印2次。 操作顺序不是由标准确定的,所以它的作用是什么:
ctime
,这会将表示保存在内部缓冲区中并返回指向它的指针。ctime
,该参数将表示保存在同一个内部缓冲区中并返回指向它的指针。解决方案是通过将操作除以;
#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;
}