這篇文章主要講解了“shell下time”命令的輸出詳解”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“shell下time”命令的輸出詳解”吧!
成都創新互聯公司2013年至今,先為濟南等服務建站,濟南等地企業,進行企業商務咨詢服務。為濟南企業網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。前言
相信大家都知道bash下time是一個很有用的命令,它可以為一段腳本或一個程序的執行計時,這通常在粗略比較程序執行效率的時候很方便。但是你會發現,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
通過上面的嘗試,發現無法將time的輸出信息重定向到文件里面,為什么?因為time是shell的關鍵字,shell做了特殊處理,它會把time命令后面的命令行作為一個整體來進行處理,在重定向時,實際上是針對后面的命令來的,time命令本身的輸出并不會被重定向的。
關鍵字time設置了一個標記,知道command(find)
命令執行完,timing信息才被打印到stderr中。time關鍵字要整個command和管道,還有相關的重定向都要來得高級。這就是為什么簡單的重定向對于time而言不起作用。 這是Bash語法定義的。command之后的重定向對于time而言,是command的一部分。
注:time命令的輸出到標準錯誤(stderr)中
當time命令執行時,command運行于當前shell(也就是time命令所執行的shell)的下一級shell,而time自身的輸出位于當前shell的stderr。像上面所示的那樣重定向只會使得command的stdout被重定向至一個文本文件,而不會輸出time自身的輸出內容。
第一種解決方法,就是將time命令和將要執行的命令行放到一個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
第一種方式的嘗試成功了,總結起來就是 { 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]#
第二種方式的嘗試也成功了,總結起來就是(time command-line) 2>file
這里time緊貼著小括號(也可以的,命令行結束也不必帶分號。當然好還是用第一種方式,畢竟啟動一個子shell是要多占些資源的。
感謝各位的閱讀,以上就是“shell下time”命令的輸出詳解”的內容了,經過本文的學習后,相信大家對shell下time”命令的輸出詳解這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創新互聯網站建設公司,,小編將為大家推送更多相關知識點的文章,歡迎關注!
分享名稱:shell下time”命令的輸出詳解-創新互聯
本文鏈接:http://vcdvsql.cn/article26/cdjpcg.html
成都網站建設公司_創新互聯,為您提供網站設計、外貿網站建設、用戶體驗、搜索引擎優化、動態網站、網站內鏈
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯