国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

總結(jié)UNIX/LINUX下C++程序計(jì)時(shí)的方法

2020-05-23 14:00:59
字體:
供稿:網(wǎng)友

前言

良好的計(jì)時(shí)器可幫助程序開發(fā)人員確定程序的性能瓶頸,或?qū)Σ煌惴ㄟM(jìn)行性能比較。但要精確測(cè)量程序的運(yùn)行時(shí)間并不容易,因?yàn)檫M(jìn)程切換、中斷、共享的多用戶、網(wǎng)絡(luò)流量、高速緩存訪問及轉(zhuǎn)移預(yù)測(cè)等因素都會(huì)對(duì)程序計(jì)時(shí)產(chǎn)生影響。

下面看看小編為大家整理幾個(gè)計(jì)時(shí)方法

方法一:

如果是想統(tǒng)計(jì)某個(gè)程序的運(yùn)行時(shí)間,那么可以使用

time ./a.out

方法二:

如果是想對(duì)某個(gè)函數(shù)或者語句進(jìn)行計(jì)時(shí),那么有別的方法。比如說,gettimeofday函數(shù)。直接貼示例代碼:

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

gettimeofday只能精確到微秒,并且它受系統(tǒng)時(shí)鐘的影響(它的原理就是通過讀取系統(tǒng)時(shí)鐘,因此當(dāng)計(jì)時(shí)的這段時(shí)間里有其他程序修改了系統(tǒng)時(shí)鐘,那么結(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所花時(shí)間為 //deltaT = (t2.tv_sec - t1.tv_sec) * 10^9 + t2.tv_nsec - t1.tv_nsec 納秒 return 0;}

這里說的都是wall clock,如果想獲得cpu執(zhí)行時(shí)間,以及了解clock_gettime參數(shù)的解釋和可能的取值,可以man一下。

總結(jié)

以上就是在UNIX/LINUX下C++程序計(jì)時(shí)的方法的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家學(xué)習(xí)使用C++程序能有所幫助。如有疑問歡迎大家留言討論。


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 荣成市| 图木舒克市| 茂名市| 贵德县| 马边| 阿拉善右旗| 军事| 渝北区| 内乡县| 金昌市| 灌南县| 长兴县| 鹿泉市| 黄大仙区| 晋中市| 武陟县| 商南县| 南雄市| 宁化县| 阳谷县| 海宁市| 丁青县| 东兰县| 上蔡县| 昌黎县| 永嘉县| 天水市| 麻阳| 文山县| 红桥区| 梅河口市| 荔波县| 隆德县| 伊金霍洛旗| 广元市| 莒南县| 浦县| 济宁市| 英吉沙县| 志丹县| 晋中市|