首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在C++中计算时间差

如何在C++中计算时间差
EN

Stack Overflow用户
提问于 2009-04-08 00:14:19
回答 8查看 261.2K关注 0票数 108

在C++中计算时间差的最佳方法是什么?我对程序的执行速度进行计时,所以我对毫秒感兴趣。更好的是,seconds.milliseconds..

接受的答案是有效的,但需要包括注释中提到的ctime或time.h。

EN

回答 8

Stack Overflow用户

发布于 2013-11-06 06:22:13

如果您使用的是c++11,下面是一个简单的包装器(请参阅此gist):

代码语言:javascript
复制
#include <iostream>
#include <chrono>

class Timer
{
public:
    Timer() : beg_(clock_::now()) {}
    void reset() { beg_ = clock_::now(); }
    double elapsed() const { 
        return std::chrono::duration_cast<second_>
            (clock_::now() - beg_).count(); }

private:
    typedef std::chrono::high_resolution_clock clock_;
    typedef std::chrono::duration<double, std::ratio<1> > second_;
    std::chrono::time_point<clock_> beg_;
};

或者对于*nix上的c++03:

代码语言:javascript
复制
#include <iostream>
#include <ctime>

class Timer
{
public:
    Timer() { clock_gettime(CLOCK_REALTIME, &beg_); }

    double elapsed() {
        clock_gettime(CLOCK_REALTIME, &end_);
        return end_.tv_sec - beg_.tv_sec +
            (end_.tv_nsec - beg_.tv_nsec) / 1000000000.;
    }

    void reset() { clock_gettime(CLOCK_REALTIME, &beg_); }

private:
    timespec beg_, end_;
};

用法示例:

代码语言:javascript
复制
int main()
{
    Timer tmr;
    double t = tmr.elapsed();
    std::cout << t << std::endl;

    tmr.reset();
    t = tmr.elapsed();
    std::cout << t << std::endl;
    return 0;
}
票数 39
EN

Stack Overflow用户

发布于 2009-04-08 00:58:04

我会认真考虑Boost的使用,特别是boost::posix_time::ptime和boost::posix_time::time_duration (在http://www.boost.org/doc/libs/1_38_0/doc/html/date_time/posix_time.html)。

它是跨平台的,易于使用,在我的经验中,它提供了操作系统提供的最高级别的时间分辨率。可能也非常重要;它提供了一些非常好的IO操作符。

要使用它来计算程序执行的差异(到微秒;可能是过度杀伤力),它看起来像是这个浏览器编写的,而不是测试的

代码语言:javascript
复制
ptime time_start(microsec_clock::local_time());
//... execution goes here ...
ptime time_end(microsec_clock::local_time());
time_duration duration(time_end - time_start);
cout << duration << '\n';
票数 30
EN

Stack Overflow用户

发布于 2009-04-08 03:56:22

在Windows中:使用GetTickCount

代码语言:javascript
复制
//GetTickCount defintition
#include <windows.h>
int main()
{

    DWORD dw1 = GetTickCount();

    //Do something 

    DWORD dw2 = GetTickCount();

    cout<<"Time difference is "<<(dw2-dw1)<<" milliSeconds"<<endl;

}
票数 12
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/728068

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档