我想boost::posix_time::ptime通过网络传输一个boost::int64_t.根据将boost :: posix_time :: ptime转换为__int64的方法,我可以轻松定义自己的纪元,并且仅time_duration将该参考纪元作为64位整数传输.但是如何转换回来ptime呢?
#include <iostream>
#include <cassert>
#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/date_time/gregorian/greg_month.hpp>
using namespace std;
using boost::posix_time::ptime;
using boost::posix_time::time_duration;
using boost::gregorian::date;
int main(int argc, char ** argv){
ptime t = boost::posix_time::microsec_clock::local_time();
// convert to int64_t
ptime myEpoch(date(1970,boost::gregorian::Jan,1));
time_duration myTimeFromEpoch = t - myEpoch;
boost::int64_t myTimeAsInt = myTimeFromEpoch.ticks();
// convert back to ptime
ptime test = myEpoch + time_duration(myTimeAsInt);
assert(test == t);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
这不起作用,因为将time_durationtick计数作为参数的构造函数是私有的.我也对ptime通过简单数据类型简单地传输它的任何其他方式感兴趣.
具有毫秒分辨率的工作解决方案:
int main(int argc, char ** argv){
ptime t = boost::posix_time::microsec_clock::local_time();
// convert to int64_t
ptime myEpoch(date(1970,boost::gregorian::Jan,1));
time_duration myTimeFromEpoch = t - myEpoch;
boost::int64_t myTimeAsInt = myTimeFromEpoch.total_milliseconds();
// convert back to ptime
ptime test = myEpoch + boost::posix_time::milliseconds(myTimeAsInt);
cout << test << endl;
cout << t << endl;
time_duration diff = test - t;
assert(diff.total_milliseconds()==0);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
谢谢12a6.