Shell中腳本變量和函數變量的作用域
在shell中定義函數可以使代碼模塊化,便於復用代碼。不過腳本本身的變量和函數
的變量的作用域問題可能令你費解,在這裡梳理一下這個問題。
www.2cto.com
(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
結果: www.2cto.com
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變量。
來源 http://blog.csdn.net/ltx19860420/article/details/5570902