29讲课上习题局部变量疑问?
def fun1():a =[]
fun2(a)
print(a)
def fun2(a):
a.append(1)
print(a)
a= []
fun1()
为什么打印出来的结果是
1
1
而不是
1
0呢?
因为你是先打印再将a设置为[]的 qiuyouzhi 发表于 2020-3-25 11:11
因为你是先打印再将a设置为[]的
fun2最后把a改成空列表了啊,调用完fun2我才打印的啊 调用fun2的时候,a.append修改的是fun1中的a,之后a=[]是定义了一个fun2的局部变量
你可以用id看一下
def fun1():
a =[]
fun2(a)
print(a)
print(id(a))
def fun2(a):
a.append(1)
print(a)
print(id(a))
a= []
print(id(a))
fun1() sunrise085 发表于 2020-3-25 11:24
调用fun2的时候,a.append修改的是fun1中的a,之后a=[]是定义了一个fun2的局部变量
你可以用id看一下
可是按理说a是可变类型,a应该从始至终是一个a才对呀。 风风魔王 发表于 2020-3-25 11:27
可是按理说a是可变类型,a应该从始至终是一个a才对呀。
No!
可变类型只是可以直接在函数中使用全局变量(确切来说是使用上一层作用域的变量),但是仍然可以定义本作用具的局部变量的。
之所以能这样使用,就是因为可变类型的定义和修改是不一样的,所以在新的作用域内使用外作用于的提名变量才不用使用global关键字指出是不是全局变量
而那些不可变类型的变量,需要用global,就是因为他们的修改和定义都是使用的'='。若是不用global的话,根本分不清到底是定义了一个局部列表,还是将修改了一个全局变量。 sunrise085 发表于 2020-3-25 11:33
No!
可变类型只是可以直接在函数中使用全局变量(确切来说是使用上一层作用域的变量),但是仍然可以定 ...
也就是说a被重新赋值之后,在里层函数就再也访问不了外部的a了呗
页:
[1]