Linux Unix環境下計算C程式執行時間

2021-06-29 12:59:47 字數 1363 閱讀 7586

linux/unix環境下計算c程式執行時間可以通過clock, times, gettimeofday, getrusage來實現。

下邊分別說明其優缺點(該部分是從別的地方copy的)

clock是ansi c的標準庫函式,關於這個函式需要說明幾點。

首先,它返回的是cpu耗費在本程式上的時間。也就是說,途中sleep的話,由於cpu資源被釋放,那段時間將不被計算在內。

其次,得到的返回值其實就是耗費在本程式上的cpu時間片的數量,也就是clock tick的值。該值必須除以clocks_per_sec這個巨集值,才能最後得到ss.mmnn格式的執行時間。在posix相容系統中,clocks_per_sec的值為1,000,000的,也就是1mhz。

最後,使用這個函式能達到的精度大約為10ms。

使用times的方法:

times的用法基本和clock類似,同樣是取得cpu時間片的數量,所不同的是要除以的時間單位值為sysconf(_sc_clk_tck)。

使用gettimeofday的方法:

用gettimeofday直接提取硬體時鐘進行運算,得到的結果的精度相比前兩種方法提高了很多。

但是也正由於它提取硬體時鐘的原因,這個方法只能計算程式開始時間和結束時間的差值。而此時系統中如果在執行其他的後台程式,可能會影響到最終結果的值。如果後台繁忙,系統dispatch過多的話,並不能完全真實反映被測量函式的執行時間。

使用getrusage的方法:

getrusage得到的是程式對系統資源的占用資訊。只要指定了rusage_self,就可以得到程式本身執行所占用的系統時間。

可以說是精度最高的測量方法了。

自己試用了這四種方法,感覺需要高精度測試的話,getrusage和gettimeofday都可以選擇。需要長時間測試的話,clock也是不錯的,尤其是考慮到它的通用性。

本人首先接觸的是gettimeofday,下邊詳細介紹這個函式的使用方法:

1. 包含標頭檔案sys/time.h.

2.定義兩個結構體 struct  timeval  start、struct  timeval  end及記錄時間的變數timer.

3. 將gettimeofday(&start,null)放在需要測的**的開始部分,將gettimeofday(&end,null)放在需要測的**的結束部分.

4.語句timer = 1000000 * (end.tv_sec-start.tv_sec)+ end.tv_usec-start.tv_usec可以使timer記錄**執行時間(時間單位為us).

5.printf("timer = %ld",timer) 列印出timer的值.

示例程式:

#include

#include

int main()

Linux Unix 語言環境配置

檢視現有語言環境 locale 可用語言環境 locale a 臨時修改語言環境 aix export lang en us export lang zh cn linux export lang en us.utf 8 export lang zh cn.utf 8 永久修改系統級字符集 修改 e...

Linux Unix下makefile檔案編寫例項

最近做linux 移植,剛剛學習了下 makefile 檔案的編寫,現將心得與大家分享。一 makefile 的規則在講述這個makefile 之前,還是讓我們先來粗略地看一看 makefile 的規則。target prerequisites command target也就是乙個目標檔案,可以是...

linux unix編輯環境的設定

最近沒啥新咚咚出來,隨便寫點東西。linux unix crontab在linux下,預設進入的編輯環境是vi,如果要修改為vim,則要修改環境變數 export editor vim 注 很多人在linux下可能不會覺得vi跟vim有啥區別,一般linux環境中的vi實際上都 是alias vim...