【Boost】计时处理--timer库

Boost

timer库概述

timer 库包含三个组件,分别是:计时器类 timer、 progress_timer 和进度指示类progress_display。

timer类摘要
 class timer
 {
     public:
        timer() { _start_time = std::clock();}
        void restart() { _start_time = std::clock(); }
        double elapsed() const
        {
            return double(std::clock() - _start_time)/ CLOCK_PER_SEC;
        }
        double elapsed_min() const
        {
            return double(1)/double(CLOCK_PER_SEC);
        }
        double elapsed_max() const
        {
            return (double ( (std:: numeric_limitd<std::clock_t>::max)()) - double(_start_time)) / double(CLOCK_PER_SEC);
        }
        private:
          std::clock_t_start_time;
 };
  1. std::clock函数,返回自进程启动以来的clock数, 每秒的clock数则由宏CLOCKS_PER_SEC定义。win32精度是毫秒,而Linux下则是微秒
  2. restart()函数则重置 _start_time 重新开始计时
  3. numeric_limitd是标准库的数值极限类。
  4. timer 没有定义析构函数,这样做是正确且啊安全的,只有一个类型为clock_t的成员变量 _start_time,故没有必要实现析构函数来特意”释放资源”
使用
#include <iostream>
#include <boost/timer.hpp>
using namespace std;
using namespace boost;
int main()
{
    timer t;//声明一个计时器对象,开始计时
    cout << "max timespan: " << t.elapsed_max()/3600<< "h" << endl; //可度量的最大时间,以小时为单位
    cout << "min timespan: " << t.elapsed_min() << "s" << endl; //可度量的最小时间,以秒为单位
    // 输出已经流逝的时间
    cout << "now time elapsed: " << t.elapsed() << "s" << endl;// elapsed 过去
    return
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值