溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

shell下time”命令的輸出詳解

發(fā)布時間:2021-09-03 07:53:13 來源:億速云 閱讀:236 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要講解了“shell下time”命令的輸出詳解”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“shell下time”命令的輸出詳解”吧!

前言

相信大家都知道bash下time是一個很有用的命令,它可以為一段腳本或一個程序的執(zhí)行計時,這通常在粗略比較程序執(zhí)行效率的時候很方便。但是你會發(fā)現(xiàn),time命令輸出的時間文字不能被簡單地重定向,例如重定向至一個文本文件,只能顯示在屏幕上,這對于非交互計時很不方便。

例如:

$ time find . -name "mysql.sh" >1.txt

real 0m0.081s
user 0m0.060s
sys  0m0.020s

$ time find . -name "mysql.sh" 2>2.txt
./work186/sms/bin/mysql.sh
./work186/sms/src/scripts/mysql.sh
./work186/sms/src/scripts1/mysql.sh
./work186/sms1/bin/mysql.sh
./work186/sms1/src/scripts/mysql.sh
./temp/sms/bin/mysql.sh
./temp/sms/src/scripts/mysql.sh

real 0m0.068s
user 0m0.040s
sys  0m0.030s

通過上面的嘗試,發(fā)現(xiàn)無法將time的輸出信息重定向到文件里面,為什么?因為time是shell的關(guān)鍵字,shell做了特殊處理,它會把time命令后面的命令行作為一個整體來進行處理,在重定向時,實際上是針對后面的命令來的,time命令本身的輸出并不會被重定向的。

關(guān)鍵字time設(shè)置了一個標記,知道command(find)命令執(zhí)行完,timing信息才被打印到stderr中。time關(guān)鍵字要整個command和管道,還有相關(guān)的重定向都要來得高級。這就是為什么簡單的重定向?qū)τ趖ime而言不起作用。 這是Bash語法定義的。command之后的重定向?qū)τ趖ime而言,是command的一部分。

注:time命令的輸出到標準錯誤(stderr)中

當(dāng)time命令執(zhí)行時,command運行于當(dāng)前shell(也就是time命令所執(zhí)行的shell)的下一級shell,而time自身的輸出位于當(dāng)前shell的stderr。像上面所示的那樣重定向只會使得command的stdout被重定向至一個文本文件,而不會輸出time自身的輸出內(nèi)容。

第一種解決方法,就是將time命令和將要執(zhí)行的命令行放到一個shell代碼塊中,也就是一對大括號中,要注意空格和分號的使用。

$ { time find . -name "mysql.sh"; } 2>2.txt
./work186/sms/bin/mysql.sh
./work186/sms/src/scripts/mysql.sh
./work186/sms/src/scripts1/mysql.sh
./work186/sms1/bin/mysql.sh
./work186/sms1/src/scripts/mysql.sh
./temp/sms/bin/mysql.sh
./temp/sms/src/scripts/mysql.sh
$ cat 2.txt

real 0m0.068s
user 0m0.030s
sys  0m0.040s

第一種方式的嘗試成功了,總結(jié)起來就是 { time command-line; } 2>file  注意分隔符的使用。

另外一種方式就是使用子Shell的方式

如下所示:

$ (time find . -name "mysql.sh") 2>2.txt
./work186/sms/bin/mysql.sh
./work186/sms/src/scripts/mysql.sh
./work186/sms/src/scripts1/mysql.sh
./work186/sms1/bin/mysql.sh
./work186/sms1/src/scripts/mysql.sh
./temp/sms/bin/mysql.sh
./temp/sms/src/scripts/mysql.sh
$ cat 2.txt

real 0m0.083s
user 0m0.040s
sys  0m0.020s
[root@web186 root]#

第二種方式的嘗試也成功了,總結(jié)起來就是 (time command-line) 2>file 這里time緊貼著小括號(也可以的,命令行結(jié)束也不必帶分號。當(dāng)然最好還是用第一種方式,畢竟啟動一個子shell是要多占些資源的。

感謝各位的閱讀,以上就是“shell下time”命令的輸出詳解”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對shell下time”命令的輸出詳解這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI