1、boost::progress_timer
作用与使用:
继承自 boost::timer ,作用相同,只是其在析构函数中会输出流逝的时间,所以在使用时,只需要声明 progress_timer 对象即可,当对象离开其生命期时,会自动输出流逝时间。在同一个小程序里测量多个时间,可以加上花括号来限定其生命期即可。
注:
progress_timer 的构造函数是: progress_timer(std::ostream& os = std::cout),所以你也可以让它输出到指定的IO流里。另,它的输出精度只有小数点后两位。
1 #include2 #include 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 }
作用:
动态输出任务进度。
使用:
通过构造函数传入进度基数,再在合适的地方进行前置自加,来更新进度。
注:
固有缺陷是不能把进度输出与程序输出分离,所以如果程序中也有输出操作,那么输出格式就会显得很乱。一个解决的办法是,在每次显示进度的时候,都调用 restart() 重新显示进度刻度,然后用 operator+=来指定当前进度,而不是简单的调用 operator++。
#include#include 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; //更新进度显示 } }
输出: