最近簡單學習了下Linux下C++程序計時的一些函數和方法,總結如下.
方法一:
如果是想統計某個程序的運行時間,那麼可以使用
[code]time ./a.out方法二:
如果是想對某個函數或者語句進行計時,那麼有別的方法。比如說,gettimeofday函數。直接貼示例代碼:
[code]#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只能精確到微秒,並且它受系統時鐘的影響(它的原理就是通過讀取系統時鐘,因此當計時的這段時間裡有其他程序修改了系統時鐘,那麼結果將不准確)。
如果想精確到納秒呢?繼續往下看:
方法三:
[code]#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一下。