總結(jié)UNIX/LINUX下C++程序計時的方法
前言
良好的計時器可幫助程序開發(fā)人員確定程序的性能瓶頸,或?qū)Σ煌惴ㄟM行性能比較。但要精確測量程序的運行時間并不容易,因為進程切換、中斷、共享的多用戶、網(wǎng)絡(luò)流量、高速緩存訪問及轉(zhuǎn)移預(yù)測等因素都會對程序計時產(chǎn)生影響。
下面看看小編為大家整理幾個計時方法
方法一:
如果是想統(tǒng)計某個程序的運行時間,那么可以使用
time ./a.out
方法二:
如果是想對某個函數(shù)或者語句進行計時,那么有別的方法。比如說,gettimeofday
函數(shù)。直接貼示例代碼:
#include <sys/time.h> void f() { //... } int main() { struct timeval t1, t2; gettimeofday(&t1, NULL); f(); gettimeofday(&t2, NULL); //那么函數(shù)f運行所花的時間為 //deltaT = (t2.tv_sec-t1.tv_sec) * 1000000 + t2.tv_usec-t1.tv_usec 微秒 return 0; }
gettimeofday
只能精確到微秒,并且它受系統(tǒng)時鐘的影響(它的原理就是通過讀取系統(tǒng)時鐘,因此當(dāng)計時的這段時間里有其他程序修改了系統(tǒng)時鐘,那么結(jié)果將不準(zhǔn)確)。
如果想精確到納秒呢?繼續(xù)往下看:
方法三:
#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執(zhí)行時間,以及了解clock_gettime
參數(shù)的解釋和可能的取值,可以man一下。
總結(jié)
以上就是在UNIX/LINUX下C++程序計時的方法的全部內(nèi)容,希望本文的內(nèi)容對大家學(xué)習(xí)使用C++程序能有所幫助。如有疑問歡迎大家留言討論。
相關(guān)文章
C語言數(shù)據(jù)結(jié)構(gòu)之vector底層實現(xiàn)機制解析
向量(Vector)是一個封裝了動態(tài)大小數(shù)組的順序容器(Sequence?Container)。跟任意其它類型容器一樣,它能夠存放各種類型的對象。可以簡單的認(rèn)為,向量是一個能夠存放任意類型的動態(tài)數(shù)組2021-11-11C++ 關(guān)于 CMFCPropertyGridCtrl 的使用方法
這篇文章主要介紹了C++ 關(guān)于 CMFCPropertyGridCtrl 的使用方法的相關(guān)資料,需要的朋友可以參考下2015-06-06