Shell中腳本變量和函數變量的做用域

      在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

相關文章
相關標籤/搜索