作為一個(gè)嵌入式Linux工程師,肯定需要編寫 shell 腳本進(jìn)行一些自動(dòng)化工作。剛好,我最近就有類似需求——一鍵交叉編譯 DDS。本著“編寫漂亮代碼的原則”,我用到了 shell 函數(shù)。
基本語法:
[function] function_name [()]{ do something [return int;]}
[function]:雖然這個(gè)關(guān)鍵字可以省略不寫,我還是建議寫上,方便閱讀;
(資料圖)
function_name:函數(shù)名稱;
do something:函數(shù)體,實(shí)現(xiàn)函數(shù)的具體功能;
[return int]:函數(shù)返回值,return是關(guān)鍵字,int為具體數(shù)值(0,1,2,…)。這個(gè)關(guān)鍵字也可以省略不寫,這樣函數(shù)將以最后一條命令運(yùn)行的結(jié)果作為返回值。
注:帶方括號(hào)的關(guān)鍵字可以省略。
#!/bin/shtest_funfunction test_fun(){ echo "shell function test!"}test_fun
執(zhí)行結(jié)果:
定義函數(shù)后,在調(diào)用函數(shù)時(shí)可以向函數(shù)傳入?yún)?shù)。和編程語言不同的是,shell 中定義函數(shù)時(shí) 無需聲明參數(shù),即帶參數(shù)的函數(shù)定義還是原始的格式:
[function] function_name [()]{ do something [return int;]}
向函數(shù)傳入?yún)?shù)時(shí)只需在調(diào)用的位置直接輸入?yún)?shù)即可,中間用空格隔開:
function_name arg1 arg2 arg3 ...
在函數(shù)內(nèi)部訪問參數(shù)時(shí)使用 的形式,n 為 1,2,3,4 …
#!/bin/shfunction test_fun(){ echo "arg1:${1}" echo "arg2:${2}" echo "arg3:${3}" echo "arg4:${4}" echo "arg num:$#" echo "${0}:${0}"}#調(diào)用函數(shù)test_fun "apple" "pear" "banana" "orange"
${0}:代表的是腳本的名稱,和 C 語言 main 函數(shù)中的 argv[0] 意義相同。
$#:存儲(chǔ)的是參數(shù)的個(gè)數(shù)。
""和 **@都表示傳遞給函數(shù)的所有*參數(shù)的集合。沒有被雙引號(hào)包圍時(shí),這兩個(gè)的值相同。如果被雙引號(hào)包圍,那么意義就不同了:
"$*" 表示將所有的參數(shù)合并到一起, 成為一個(gè)參數(shù);
"$@" 表示所有的參數(shù)仍然是分離的。
通過 for
循環(huán)就能看出區(qū)別:
#!/bin/shfunction test_fun(){ echo "item in $*" for var in "$*" do echo "$var" done echo "item in $@" for var in "$@" do echo "$var" done}
你可能會(huì)遇到這樣的場(chǎng)景——在函數(shù)中,你只想 使用后面的幾個(gè)參數(shù),忽略前面的參數(shù)。
這個(gè)時(shí)候就可以使用 shift
關(guān)鍵字了。
shift n
將全部參數(shù) 向左移動(dòng) n 個(gè)位置,后面的參數(shù)移動(dòng)到前面參數(shù)的位置,前面的參數(shù)被丟棄。比如 shift 2
指令的最終結(jié)果是把原來的 **{3} 移動(dòng)到 {1} 的位置,{4}移動(dòng)到 **{2} 的位置 …
#!/bin/shfunction test_fun(){ echo "${1}:${1}" echo "${2}:${2}" echo "${3}:${3}" echo "${4}:${4}" shift 1 echo "after shift 1:" echo "${1}:${1}" echo "${2}:${2}" echo "${3}:${3}"}test_fun "apple" "pear" "banana" "orange"
嗯,shell 函數(shù)挺好用的!
標(biāo)簽: