尹绵绵

 

利用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实在是强大...

posted on 2012-05-14 20:24  花无形  阅读(2450)  评论(0编辑  收藏  举报

导航