马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
var = ' Hi '
def fun1():
global var
var = ' Baby '
return fun2(var)
def fun2(var):
var += 'I love you'
fun3(var)
return var
def fun3(var):
var = ' 小甲鱼 '
print(fun1())
为什么输出结果是:“Baby,I love you”
先说个 Python 的屏蔽机制吧(Ps:都是指没有 global 和 nonlocal声明下,因为如果声明了就不是局部变量了):
当函数内部的变量和函数外部全局作用域的变量名相同时,会触发 Python 的屏蔽机制,函数内部会创建一个同名的局部变量
来暂时覆盖同名的全局变量,此时在函数内部的值都为这个局部变量,只要一出此函数,那么该局部变量就不复存在,变会原来的全局变量
了解了上面的屏蔽机制我们在来看看代码:先调用的是 fun1():def fun1():
global var # 声明变量是全局变量
var = ' Baby ' # 对全局变量重新赋值
return fun2(var)
这边用global 声明了 var 函数是全局变量,所以就不会触发屏蔽机制,给 var 重新赋值 'Baby' 导致覆盖之前的 var ,var = 'Baby' 返回 fun2
然后运行带 fun2(var) 此时传入的var = 'Baby':def fun2(var):
var += 'I love you' # 没有声明全局变量 则这可以看成 var = var + 'I love you' 这里等号右边的 var 是全局变量 等号左边的 var 是局部变量
fun3(var)
return var
因为 var += 'I love you' 可以等价看成 var = var + 'I love you' 所以 var 拼接上'I love you' 时 重新赋值给 var 触发屏蔽机制
此时暂时屏蔽全局变量的 var = ' Baby ' ,而为 var = ' Baby I love you ' 局部变量 ,然后传入fun3函数def fun3(var):
var = ' 小甲鱼 ' # 没有声明,是局部变量
这边再次屏蔽机制,因为对于fun3来说 fun2函数内以及fun2函数外的都算是全局作用域,所以这里赋值 var = ' 小甲鱼 ' 时
暂时屏蔽了 var = ' Baby I love you ' 但是一出 fun3就不复存在 变全局变量 var = ' Baby I love you '
所以最后回到 fun2 返回结果为 var局部变量的结果,即是 Baby I love you
|