|  | 
 
| 
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
 
 
 | 
 |