在shell中定義函數可使代碼模塊化,便於複用代碼。不過腳本自己的變量和函數的變量的做用域問題可能令你費解,在這裏梳理一下這個問題。
(1)Shell腳本中定義的變量是global的,其做用域從被定義的地方開始,到shell結束或被顯示刪除的地方爲止。
例1:腳本變量的做用域
#!/bin/bash
#define the function ltx_func
ltx_func()
{
echo $v1
#modify the variable v1
v1=200
}
#define the variable v1
v1=100
#call the function ltx_func
ltx_func
echo $v1
結果:
100
200
解析:腳本變量v1的做用域從被定義的地方開始,到shell結束。調用函數ltx_func的地方在變量v1的做用域內,因此可以訪問並修改變量v1。
(2)Shell函數定義的變量默認是global的,其做用域從「函數被調用時執行變量定義的地方」開始,到shell結束或被顯示刪除處爲止。函數定義的變量能夠被顯示定義成local的,其做用域侷限於函數內。但請注意,函數的參數是local的。
例2:函數定義的global變量
#!/bin/bash
#define the function ltx_func
ltx_func()
{
#define the variable v2
v2=200
}
#call the function ltx_func
ltx_func
echo $v2
結果:
200
解析:函數變量v2默認是global的,其做用域從「函數被調用時執行變量定義的地方」開始,到shell結束爲止。注意,不是從定義函數的地方開始,而是從調用函數的地方開始。打印命令在變量v2的做用域內,因此可以訪問變量v2。
例3:函數定義的local變量
#!/bin/bash
#define the function ltx_func
ltx_func()
{
#define the local variable v2
local v2=200
}
#call the function ltx_func
ltx_func
echo $v2
結果:
(空)
解析:函數變量v2顯示定義爲local的,其做用域侷限於函數內。打印命令在函數外,不在變量v2的做用域內,因此可以不能訪問變量v2。
例4:函數參數是local變量
#!/bin/bash
#define the function ltx_func
ltx_func()
{
echo "param 1: $1"
}
#call the function ltx_func
ltx_func 100
結果:
100
解析:函數參數是local的,經過位置變量來訪問。打印命令輸出函數的第一個參數。
(3)若是同名,Shell函數定義的local變量會屏蔽腳本定義的global變量。
例5:同名local變量屏蔽global變量
#!/bin/bash
#define the function ltx_func
ltx_func()
{
echo $v1
#define the local variable v1
local v1=200
echo $v1
}
#define the global variable v1
v1=200
#call the function ltx_func
ltx_func
echo $v1
結果:
100
200
100
解析:global變量v1的做用域從被定義的地方開始,到shell結束。調用函數ltx_func的地方在變量v1的做用域內,因此可以變量v1。函數又定義了同名的local變量v1,同名local變量屏蔽global變量,因此函數第二次打印訪問的是local變量。退出函數後再次打印v1,此時函數定義的local變量已經消失,訪問的是global變量。 shell
在此聲明,能夠轉載或引用,但必須註明出處。 bash