简体   繁体   English

使用 C++ 和 Boost 获取当前时间(以毫秒为单位)

[英]Get current time in milliseconds using C++ and Boost

In my thread (using boost::thread) I need to retrieve the current time in ms or less and to convert into ms:在我的线程中(使用 boost::thread)我需要以 ms 或更短的时间检索当前时间并转换为 ms:

Actually, reading here I've found this:实际上,在这里阅读我发现了这一点:

tick = boost::posix_time::second_clock::local_time();
now  = boost::posix_time::second_clock::local_time();

And seems to work, but after I need to have a long value of the milliseconds of the now...并且似乎有效,但是在我需要一个很长的毫秒值之后......

How can I do it?我该怎么做?

You can use boost::posix_time::time_duration to get the time range.您可以使用boost::posix_time::time_duration来获取时间范围。 Eg like this比如像这样

boost::posix_time::time_duration diff = tick - now;
diff.total_milliseconds();

And to get a higher resolution you can change the clock you are using.为了获得更高的分辨率,您可以更改您正在使用的时钟。 For example to the boost::posix_time::microsec_clock , though this can be OS dependent.例如boost::posix_time::microsec_clock ,尽管这可能取决于操作系统。 On Windows, for example, boost::posix_time::microsecond_clock has milisecond resolution, not microsecond.例如,在 Windows 上, boost::posix_time::microsecond_clock具有毫秒分辨率,而不是微秒。

An example which is a little dependent on the hardware.一个有点依赖于硬件的例子。

int main(int argc, char* argv[])
{
    boost::posix_time::ptime t1 = boost::posix_time::second_clock::local_time();
    boost::this_thread::sleep(boost::posix_time::millisec(500));
    boost::posix_time::ptime t2 = boost::posix_time::second_clock::local_time();
    boost::posix_time::time_duration diff = t2 - t1;
    std::cout << diff.total_milliseconds() << std::endl;

    boost::posix_time::ptime mst1 = boost::posix_time::microsec_clock::local_time();
    boost::this_thread::sleep(boost::posix_time::millisec(500));
    boost::posix_time::ptime mst2 = boost::posix_time::microsec_clock::local_time();
    boost::posix_time::time_duration msdiff = mst2 - mst1;
    std::cout << msdiff.total_milliseconds() << std::endl;
    return 0;
}

On my win7 machine.在我的win7机器上。 The first out is either 0 or 1000. Second resolution.第一个输出是 0 或 1000。第二个分辨率。 The second one is nearly always 500, because of the higher resolution of the clock.第二个几乎总是 500,因为时钟的分辨率更高。 I hope that help a little.我希望能有所帮助。

If you mean milliseconds since epoch you could do如果您的意思是自纪元以来的毫秒数,您可以这样做

ptime time_t_epoch(date(1970,1,1)); 
ptime now = microsec_clock::local_time();
time_duration diff = now - time_t_epoch;
x = diff.total_milliseconds();

However, it's not particularly clear what you're after.但是,目前还不清楚你在追求什么。

Have a look at the example in the documentation for DateTime at Boost Date Time查看文档中 DateTime at Boost Date Time的示例

// Get current date/time in milliseconds.
#include "boost/date_time/posix_time/posix_time.hpp"
namespace pt = boost::posix_time;

int main()
{
     pt::ptime current_date_microseconds = pt::microsec_clock::local_time();

    long milliseconds = current_date_microseconds.time_of_day().total_milliseconds();

    pt::time_duration current_time_milliseconds = pt::milliseconds(milliseconds);

    pt::ptime current_date_milliseconds(current_date_microseconds.date(), 
                                        current_time_milliseconds);

    std::cout << "Microseconds: " << current_date_microseconds 
              << " Milliseconds: " << current_date_milliseconds << std::endl;

    // Microseconds: 2013-Jul-12 13:37:51.699548 Milliseconds: 2013-Jul-12 13:37:51.699000
}

Try this: import headers as mentioned.. gives seconds and milliseconds only.试试这个:前面提到的 import headers .. 只给出秒和毫秒。 If you need to explain the code read this link .如果您需要解释代码,请阅读此链接

#include <windows.h>

#include <stdio.h>

void main()
{

    SYSTEMTIME st;
    SYSTEMTIME lt;

    GetSystemTime(&st);
   // GetLocalTime(&lt);

     printf("The system time is: %02d:%03d\n", st.wSecond, st.wMilliseconds);
   //  printf("The local time is: %02d:%03d\n", lt.wSecond, lt.wMilliseconds);

}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM