如何在 Bash 中編寫函數
通過編寫函數來減少代碼的冗餘和維護。
在編程時,實際上是在定義要由計算機執行的 過程 或 常式 。一個簡單的類比是將計算機編程與烤麵包進行比較:你一次列出了要組建工作環境的配料,然後列出了烤麵包所必須採取的步驟。在編程和烘烤中,必須以不同的間隔重複執行某些步驟。例如,在烤麵包中,這可能是酵母培養的過程:
STIR=100
SNOOZE=86400
function feed_culture {
remove_from(pantry)
add(flour, water)
stir($STIR)
sleep($SNOOZE)
}
然後,揉面和醒發麵團:
KNEAD=600
SNOOZE=7200
function process_dough {
remove_from(proofing_drawer)
knead($KNEAD)
return_to_drawer($SNOOZE)
}
在編程中,這些 子常式 可以表示為 函數 。函數對程序員很重要,因為它們有助於減少代碼中的冗餘,從而減少了所需的維護量。例如,在以編程方式烤制麵包的假想場景中,如果你需要更改麵糰醒發的用時,只要你之前使用函數,那麼你只需更改一次用時,或使用變數(在示例代碼中為 SNOOZE
)或直接在處理麵糰的子程序中更改用時。這樣可以節省你很多時間,因為你不必通過你的代碼庫遍歷每個可能正在醒發的麵糰,更不用說擔心錯過一個。許多 bug 是由未更改的缺失的值或執行不正確的 sed
命令引起的,它們希望捕獲所有可能而不必手動尋找。
在 Bash 中,無論是在編寫的腳本或在獨立的文件中,定義函數和使用它們一樣簡單。如果將函數保存到獨立的文件中。那麼可以將它 source
到腳本中,就像 include
C 語言或 C++ 中的庫或將模塊 import
到 Python 中一樣。要創建一個 Bash 函數,請使用關鍵字 function
:
function foo {
# code here
}
這是一個如何在函數中使用參數的例子(有些人為設計,因此可能會更簡單):
#!/usr/bin/env bash
ARG=$1
function mimic {
if [[ -z $ARG ]]; then
ARG='world'
fi
echo "hello $ARG"
}
mimic $ARG
結果如下:
$ ./mimic
hello world
$ ./mimic everybody
hello everybody
請注意腳本的最後一行,它會執行該函數。對於編寫腳本的新手來說,這是一個普遍的困惑點:函數不會自動執行。它們作為潛在的常式存在,直到被調用。
如果沒有調用該函數,那麼函數只是被定義,並且永遠不會運行。
如果你剛接觸 Bash,請嘗試在包含最後一行的情況下執行示例腳本一次,然後在注釋掉最後一行的情況下再次執行示例腳本。
使用函數
即使對於簡單的腳本,函數也是很重要的編程概念。你越適應函數,在面對一個不僅需要聲明性的命令行,還需要更多動態的複雜問題時,你就會越容易。將通用函數保存在單獨的文件中還可以節省一些工作,因為它將幫助你建立常用的程序,以便你可以在項目間重用它們。看看你的腳本習慣,看是否適合使用函數。
via: https://opensource.com/article/20/6/bash-functions
作者:Seth Kenlon 選題:lujun9972 譯者:geekpi 校對:wxy
本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive