利用Boost在windows下取微秒级时间点
前一段时间想在windows下去微秒级时间点,但是windows本身提供的API只能精确到毫秒级。
找到过一个帖子讲利用一段时间内CPU的转数和CPU频率取得两个时间点间的微秒级时间间隔,但还是无法取微秒级时间点。
偶然发现Boost.date_time库提供了取精确到微秒级的时间点的方法,代码如下:
1 #include <iostream> 2 #include <boost/date_time/posix_time/posix_time.hpp> 3 using namespace std; 4 using namespace boost::posix_time; 5 6 int main() { 7 ptime now = microsec_clock::universal_time() + hours(8); 8 cout << now << endl; 9 cout << now.time_of_day().total_microseconds() << endl; 10 }
microsec_clock::universal_time()即取得当前时间,但是这个时间是格林尼治标准时间,后面加个hours(8)即为东八区的时间。
total_microsecornds()取得当日已走过的微秒数。
最后感叹下Boost实在是强大...