progress_timer继承自timer,但是精度为2,为了扩展精度,我们自己实现一个类,代码如下:
#include <iostream> #include<boost/progress.hpp> #include <boost/static_assert.hpp> using namespace std; using namespace boost; template<int N=2> class new_progress_timer :public timer{ public: new_progress_timer(ostream &os=cout):m_os(os){ BOOST_STATIC_ASSERT(N>=0&&NULL<=10); } ~new_progress_timer(){ try{ istream::fmtflags old_flags=m_os.setf(istream::fixed,istream::floatfield); streamsize old_prec=m_os.precision(N); //输出时间 m_os<<elapsed()<<"s\n"<<endl; //恢复流的状态 m_os.flags(old_flags); m_os.precision(old_prec); }catch(...){ //do nothing } } private: ostream &m_os; }; int _tmain(int argc, _TCHAR* argv[]) { new_progress_timer<10> t; //cout<<t.elapsed(); 这里不需要亲自调用,当超过t的作用域的时候自动调用 return 0; }