Linux命令 time - 統(tǒng)計給定命令所花費的總時間

2022-03-22 09:24 更新

time

統(tǒng)計給定命令所花費的總時間

補充說明

time命令 用于統(tǒng)計給定命令所花費的總時間。

語法

time(參數(shù))

參數(shù)

指令:指定需要運行的額指令及其參數(shù)。

實例

當(dāng)測試一個程序或比較不同算法時,執(zhí)行時間是非常重要的,一個好的算法應(yīng)該是用時最短的。所有類UNIX系統(tǒng)都包含time命令,使用這個命令可以統(tǒng)計時間消耗。例如:

[root@localhost ~]# time ls
anaconda-ks.cfg  install.log  install.log.syslog  satools  text

real    0m0.009s
user    0m0.002s
sys     0m0.007s

輸出的信息分別顯示了該命令所花費的real時間、user時間和sys時間。

  • real時間是指掛鐘時間,也就是命令開始執(zhí)行到結(jié)束的時間。這個短時間包括其他進程所占用的時間片,和進程被阻塞時所花費的時間。
  • user時間是指進程花費在用戶模式中的CPU時間,這是唯一真正用于執(zhí)行進程所花費的時間,其他進程和花費阻塞狀態(tài)中的時間沒有計算在內(nèi)。
  • sys時間是指花費在內(nèi)核模式中的CPU時間,代表在內(nèi)核中執(zhí)系統(tǒng)調(diào)用所花費的時間,這也是真正由進程使用的CPU時間。

shell內(nèi)建也有一個time命令,當(dāng)運行time時候是調(diào)用的系統(tǒng)內(nèi)建命令,應(yīng)為系統(tǒng)內(nèi)建的功能有限,所以需要時間其他功能需要使用time命令可執(zhí)行二進制文件/usr/bin/time。

使用-o選項將執(zhí)行時間寫入到文件中:

/usr/bin/time -o outfile.txt ls

使用-a選項追加信息:

/usr/bin/time -a -o outfile.txt ls

使用-f選項格式化時間輸出:

/usr/bin/time -f "time: %U" ls

-f選項后的參數(shù):

參數(shù)描述
%Ereal時間,顯示格式為[小時:]分鐘:秒
%Uuser時間。
%Ssys時間。
%C進行計時的命令名稱和命令行參數(shù)。
%D進程非共享數(shù)據(jù)區(qū)域,以KB為單位。
%x命令退出狀態(tài)。
%k進程接收到的信號數(shù)量。
%w進程被交換出主存的次數(shù)。
%Z系統(tǒng)的頁面大小,這是一個系統(tǒng)常量,不用系統(tǒng)中常量值也不同。
%P進程所獲取的CPU時間百分百,這個值等于 user+system 時間除以總共的運行時間。
%K進程的平均總內(nèi)存使用量(data+stack+text),單位是 KB。
%w進程主動進行上下文切換的次數(shù),例如等待I/O操作完成。
%c進程被迫進行上下文切換的次數(shù)(由于時間片到期)。


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號