boost::progress_timer 与 boost::progress_display

1、boost::progress_timer

作用与使用:

继承自 boost::timer ,作用相同,只是其在析构函数中会输出流逝的时间,所以在使用时,只需要声明 progress_timer 对象即可,当对象离开其生命期时,会自动输出流逝时间。在同一个小程序里测量多个时间,可以加上花括号来限定其生命期即可。

 

注:

progress_timer 的构造函数是: progress_timer(std::ostream& os = std::cout),所以你也可以让它输出到指定的IO流里。另,它的输出精度只有小数点后两位。

 1   #include <iostream>
 2   #include <boost/progress.hpp>
 3 
 4   int main()
 5   {
 6       {
 7           boost::progress_timer t;
 8           for(int i = 0; i< 100000000;i++)
 9           {
10               ;
11           }
12       }
13       {
14           boost::progress_timer t;
15           for(int i = 0; i< 100000000;i++)
16           {
17               ;
18           }
19       }
20   }


2、boost::progress_display

作用:

动态输出任务进度。

 

使用:

通过构造函数传入进度基数,再在合适的地方进行前置自加,来更新进度。

 

注:

固有缺陷是不能把进度输出与程序输出分离,所以如果程序中也有输出操作,那么输出格式就会显得很乱。一个解决的办法是,在每次显示进度的时候,都调用 restart() 重新显示进度刻度,然后用 operator+=来指定当前进度,而不是简单的调用 operator++。

  #include <iostream>
  #include <boost/progress.hpp>

  int main()
  {
      int i(100000000),j(100000000),k(1);
      boost::progress_display pd(i);
      boost::progress_timer t;
      while(i>0)
      {
          while(j>0)
          {
              j--;
          }
          i--;
          ++pd;   //更新进度显示
      }
  }

输出:

 

 

posted @ 2012-09-13 14:09  轻典  阅读(1477)  评论(0编辑  收藏  举报