通過編寫函數來減少代碼的冗余和維護。
- 來源:https://linux.cn/article-12323-1.html
- 作者:Seth Kenlon
- 譯者:geekpi
(本文字數:1791,閱讀時長大約:2 分鐘)
通過編寫函數來減少代碼的冗余和維護。
在編程時,實際上是在定義要由計算機執行的 過程(procedure)或 例程(routine)。一個簡單的類比是將計算機編程與烤面包進行比較:你一次列出了要組建工作環境的配料,然后列出了烤面包所必須采取的步驟。在編程和烘烤中,必須以不同的間隔重復執行某些步驟。例如,在烤面包中,這可能是酵母培養的過程:
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)
}
在編程中,這些 子例程(subroutines)可以表示為 函數(function)。函數對程序員很重要,因為它們有助于減少代碼中的冗余,從而減少了所需的維護量。例如,在以編程方式烤制面包的假想場景中,如果你需要更改面團醒發的用時,只要你之前使用函數,那么你只需更改一次用時,或使用變量(在示例代碼中為 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
本文由 LCTT 原創編譯, Linux中國 榮譽推出