您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關怎么在Bash中編寫函數的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
通過編寫函數來減少代碼的冗余和維護。
在編程時,實際上是在定義要由計算機執(zhí)行的過程或例程。一個簡單的類比是將計算機編程與烤面包進行比較:你一次列出了要組建工作環(huán)境的配料,然后列出了烤面包所必須采取的步驟。在編程和烘烤中,必須以不同的間隔重復執(zhí)行某些步驟。例如,在烤面包中,這可能是酵母培養(yǎng)的過程:
STIR=100SNOOZE=86400 function feed_culture { remove_from(pantry) add(flour, water) stir($STIR) sleep($SNOOZE)}
然后,揉面和醒發(fā)面團:
KNEAD=600SNOOZE=7200 function process_dough { remove_from(proofing_drawer) knead($KNEAD) return_to_drawer($SNOOZE)}
在編程中,這些子例程可以表示為函數。函數對程序員很重要,因為它們有助于減少代碼中的冗余,從而減少了所需的維護量。例如,在以編程方式烤制面包的假想場景中,如果你需要更改面團醒發(fā)的用時,只要你之前使用函數,那么你只需更改一次用時,或使用變量(在示例代碼中為 SNOOZE
)或直接在處理面團的子程序中更改用時。這樣可以節(jié)省你很多時間,因為你不必通過你的代碼庫遍歷每個可能正在醒發(fā)的面團,更不用說擔心錯過一個。許多 bug 是由未更改的缺失的值或執(zhí)行不正確的 sed
命令引起的,它們希望捕獲所有可能而不必手動尋找。
在 Bash 中,無論是在編寫的腳本或在獨立的文件中,定義函數和使用它們一樣簡單。如果將函數保存到獨立的文件中。那么可以將它 source
到腳本中,就像 include
C 語言或 C++ 中的庫或將模塊 import
到 Python 中一樣。要創(chuàng)建一個 Bash 函數,請使用關鍵字 function
:
function foo {# code here}
這是一個如何在函數中使用參數的例子(有些人為設計,因此可能會更簡單):
#!/usr/bin/env bashARG=$1 function mimic { if [[ -z $ARG ]]; then ARG='world' fi echo "hello $ARG"} mimic $ARG
結果如下:
$ ./mimichello world$ ./mimic everybodyhello everybody
請注意腳本的最后一行,它會執(zhí)行該函數。對于編寫腳本的新手來說,這是一個普遍的困惑點:函數不會自動執(zhí)行。它們作為潛在的例程存在,直到被調用。
如果沒有調用該函數,那么函數只是被定義,并且永遠不會運行。
如果你剛接觸 Bash,請嘗試在包含最后一行的情況下執(zhí)行示例腳本一次,然后在注釋掉最后一行的情況下再次執(zhí)行示例腳本。
即使對于簡單的腳本,函數也是很重要的編程概念。你越適應函數,在面對一個不僅需要聲明性的命令行,還需要更多動態(tài)的復雜問題時,你就會越容易。將通用函數保存在單獨的文件中還可以節(jié)省一些工作,因為它將幫助你建立常用的程序,以便你可以在項目間重用它們。
感謝各位的閱讀!關于“怎么在Bash中編寫函數”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。