在C++中计算时间差的最佳方法是什么?我对程序的执行速度进行计时,所以我对毫秒感兴趣。更好的是,seconds.milliseconds..
接受的答案是有效的,但需要包括注释中提到的ctime或time.h。
发布于 2013-11-06 06:22:13
如果您使用的是c++11,下面是一个简单的包装器(请参阅此gist):
#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:
#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_;
};
用法示例:
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;
}
发布于 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操作符。
要使用它来计算程序执行的差异(到微秒;可能是过度杀伤力),它看起来像是这个浏览器编写的,而不是测试的
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';
发布于 2009-04-08 03:56:22
在Windows中:使用GetTickCount
//GetTickCount defintition
#include <windows.h>
int main()
{
DWORD dw1 = GetTickCount();
//Do something
DWORD dw2 = GetTickCount();
cout<<"Time difference is "<<(dw2-dw1)<<" milliSeconds"<<endl;
}
https://stackoverflow.com/questions/728068
复制相似问题