我试图通过查看数据的时间戳来查看我的数据是否是 120 秒旧的,因此我的库项目中有以下小代码正在使用std::chrono
包裹:
uint64_t now = duration_cast<milliseconds>(steady_clock::now().time_since_epoch()).count();
bool is_old = (120 * 1000 < (now - data_holder->getTimestamp()));
// some logging to print out above values
LOG4CXX_WARN(logger, "data logging, now: " << now << ", data holder timestamp: " << data_holder->getTimestamp() << ", is_old: " << is_old << ", difference: " << (now - data_holder->getTimestamp()));
在上面的代码中data_holder->getTimestamp()
是 uint64_t,它返回以毫秒为单位的时间戳。
现在当我打印出来时now
变量值,我看到这个433425679
当我打印出来时data_holder->getTimestamp()
值为1437943796841
现在和数据持有者时间戳的差异如下:18446742636199180454
如下日志所示:
2015-07-26 13:49:56,850 WARN 0x7fd050bc9700 simple_process - data logging, now: 433425679 , data holder timestamp: 1437943796841 , is_old: 1 , difference: 18446742636199180454
现在,如果我转换数据持有者时间戳1437943796841
使用纪元转换器,我看到这个:
Your time zone: 7/26/2015, 1:49:56 PM
与日志中显示的时间戳完全相同2015-07-26 13:49:56,850 WARN
这意味着我的数据看起来不是 120 秒的旧数据。如果是,那为什么我会看到is_old
值为 1?
现在,如果我运行这个简单的主程序,我会看到is_old
返回 0 而不是 1:
#include <iostream>
int main ()
{
bool is_old = (120 * 1000 < (433425679 - 1437943796841));
std::cout<<"is_old: " << is_old << std::endl;
}
到底是怎么回事?为什么当我从 main 方法运行时它返回 0,而当我从项目中记录它时它返回 1。这是否意味着我运行主代码的方式与使用 cmake 命令构建库的方式不同?我正在使用 cmake 命令构建项目可执行文件,该命令生成一个 tar 文件,然后通过解压 tar 文件来运行它。我正在 Ubuntu 14.04 机器上运行。
早些时候,我想我需要使用system_clock
代替steady_clock
但是当我从 main 方法运行它之后,看起来好像发生了其他事情。