欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C語言

當前位置:主頁 > 軟件編程 > C語言 >

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

來源:本站原創(chuàng)|時間:2020-01-10|欄目: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)時鐘,因此當計時的這段時間里有其他程序修改了系統(tǒng)時鐘,那么結(jié)果將不準確)。

如果想精確到納秒呢?繼續(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)容對大家學習使用C++程序能有所幫助。如有疑問歡迎大家留言討論。

上一篇:C語言 條件判斷詳細介紹

欄    目:C語言

下一篇:C語言 存儲類詳解及示例代碼

本文標題:總結(jié)UNIX/LINUX下C++程序計時的方法

本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/2116.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有