亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2016年08月14日 09:18:20   投稿:daisy  
本文總結(jié)了下UNIX/LINUX下C++程序計時的一些函數(shù)和方法,對日常使用C++程序的朋友很有幫助,有需要的小伙伴們可以參考學(xué)習(xí),下面一起來看看吧。

前言

良好的計時器可幫助程序開發(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語言實現(xiàn)貪吃蛇小游戲

    C語言實現(xiàn)貪吃蛇小游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • C++利用循環(huán)和棧實現(xiàn)走迷宮

    C++利用循環(huán)和棧實現(xiàn)走迷宮

    這篇文章主要為大家詳細(xì)介紹了C++利用循環(huán)和棧實現(xiàn)走迷宮,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • QT基于TCP實現(xiàn)文件傳輸系統(tǒng)

    QT基于TCP實現(xiàn)文件傳輸系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了QT基于TCP實現(xiàn)文件傳輸系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 深度探究C++中的函數(shù)重載的用法

    深度探究C++中的函數(shù)重載的用法

    這篇文章主要介紹了C++中的函數(shù)重載用法,包括重載時參數(shù)類型的差異以及匹配和轉(zhuǎn)換等方面問題的講解,需要的朋友可以參考下
    2016-01-01
  • C++可以函數(shù)重載而C不可以的原因分析

    C++可以函數(shù)重載而C不可以的原因分析

    函數(shù)重載是指在同一個作用域內(nèi),可以定義多個函數(shù),它們具有相同的名稱但是參數(shù)列表不同,為什么C++可以函數(shù)重載而C不可以,接下來就有小編來給大家介紹一下C++可以函數(shù)重載而C不可以的原因,需要的朋友可以參考下
    2023-12-12
  • 淺析如何在c語言中調(diào)用Linux腳本

    淺析如何在c語言中調(diào)用Linux腳本

    如何在c語言中調(diào)用Linux腳本呢?下面小編就為大家詳細(xì)的介紹一下吧!需要的朋友可以過來參考下
    2013-08-08
  • C語言數(shù)據(jù)結(jié)構(gòu)之vector底層實現(xiàn)機制解析

    C語言數(shù)據(jù)結(jié)構(gòu)之vector底層實現(xiàn)機制解析

    向量(Vector)是一個封裝了動態(tài)大小數(shù)組的順序容器(Sequence?Container)。跟任意其它類型容器一樣,它能夠存放各種類型的對象。可以簡單的認(rèn)為,向量是一個能夠存放任意類型的動態(tài)數(shù)組
    2021-11-11
  • 帶你粗略了解C++流的讀寫文件

    帶你粗略了解C++流的讀寫文件

    這篇文章主要為大家總結(jié)了C++中輸入輸出流及文件流操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能給你帶來幫助
    2021-08-08
  • C++讀取INI配置文件類實例詳解

    C++讀取INI配置文件類實例詳解

    這篇文章主要介紹了C++讀取INI配置文件類的實現(xiàn)方法,需要的朋友可以參考下
    2014-07-07
  • C++ 關(guān)于 CMFCPropertyGridCtrl 的使用方法

    C++ 關(guān)于 CMFCPropertyGridCtrl 的使用方法

    這篇文章主要介紹了C++ 關(guān)于 CMFCPropertyGridCtrl 的使用方法的相關(guān)資料,需要的朋友可以參考下
    2015-06-06

最新評論