1. 程式人生 > >UNIX/LINUX下C++程式計時方法

UNIX/LINUX下C++程式計時方法

最近簡單學習了下Linux下C++程式計時的一些函式和方法,總結如下.

方法一:

如果是想統計某個程式的執行時間,那麼可以使用

time ./a.out

方法二:

如果是想對某個函式或者語句進行計時,那麼有別的方法。比如說,gettimeofday函式。直接貼示例程式碼:

#include <sys/time.h>
void f()
{
  //...
}
int main()
{
  struct timeval t1, t2;
  gettimeofday(&t1, NULL);
  f();
  gettimeofday(&t2, NULL);
  //那麼函式f執行所花的時間為
  //deltaT = (t2.tv_sec-t1.tv_sec) * 1000000
+ t2.tv_usec-t1.tv_usec 微秒 return 0; }

gettimeofday只能精確到微秒,並且它受系統時鐘的影響(它的原理就是通過讀取系統時鐘,因此當計時的這段時間裡有其他程式修改了系統時鐘,那麼結果將不準確)。

如果想精確到納秒呢?繼續往下看:

方法三:

#include <time.h>
void f()
{
  //...
}
int main()
{
  timespec t1, t2;
  clock_gettime(CLOCK_MONOTONIC, &t1);
  f();
  clock_gettime(CLOCK_MONOTONIC, &t2);
  //那麼f所花時間為
  //deltaT = (t2.tv_sec - t1.tv_sec) * 10
^9 + t2.tv_nsec - t1.tv_nsec 納秒 return 0; }

這裡說的都是wall clock,如果想獲得cpu執行時間,以及瞭解clock_gettime引數的解釋和可能的取值,可以man一下。