第020讲课后练习第6题
6. 以下是“闭包”的一个例子,请你目测下会打印什么内容?def funX():
x = 5
def funY():
nonlocal x
x += 1
return x
return funY
>>> a = funX() # funX()返回内部的闭包函数funY()对象本身,赋值给中间变量a
>>> print(a()) # 通过中间变量a调用内部的闭包函数funY()并输出
6
>>> print(a())
7
>>> print(a())
8
有些鱼油可能会比较疑惑,这……怎么跟全局变量一样了?局部变量 x 不是应该在每次调用的时候都重新初始化了吗?!
其实大家仔细看看就明白了:当 a = funX() 的时候,只要 a 变量没有被重新赋值,funX() 就没有被释放,也就是说局部变量 x 就没有被重新初始化。
所以当全局变量不适用的时候,可以考虑使用闭包更稳定和安全
疑问:
1、为何采用a = funX()调用的话,每次print(a())输出的结果都会累加1,而如果采用funX()()调用的话,每次结果都是6固定不变?
2、标注蓝色字体没看明白,尤其是最后一句:……所以当全局变量不适用的时候,可以考虑使用闭包更稳定和安全 本帖最后由 歌者文明清理员 于 2023-6-5 23:06 编辑
[*]采用 a = funX() 调用的方式,是因为每次调用 funX() 都会重新定义函数内部的变量 x,并将其赋值为 5。然而在调用完 funX() 后,a 变量已经指向了 funY() 这个闭包函数,同时 x 变量也被保存在闭包函数内部并且不会重新初始化。因此,每次调用 a() 实际上都调用了闭包函数 funY(),并对闭包函数内部的变量 x 进行操作,所以每次返回的结果都会累加1。
而如果采用 funX()() 直接调用的话,每次调用 funX() 都会新建一个闭包,内部 x 的初始值会被重新设置为 5,因此每次返回的结果都是 6,固定不变。
[*]标蓝中的字体可能指的是“局部变量 x”,如果全局变量不适用或者不能满足需求时,闭包可以作为一种稳定而且安全的选择。闭包可以将需要隐藏的信息封装在内部函数内部,防止被外界访问和修改,从而提高代码的安全性。
1. 在执行 a = funX() 时,funX()返回了内部的闭包函数 funY() 对象本身而不是它的结果,因此a指向的函数是一个闭包,即使执行完 a() ,其中的变量 x 也没有被删除和重置。每次调用 a() 都会更新并返回 x 的值,因此结果会累加。而当直接使用 funX()() 调用时,每次调用都会创建新的局部变量 x 和闭包函数 funY() ,所以结果都是6固定不变。
2. 当使用全局变量时,多个函数或过程将共享相同的变量,这可能导致代码的可预测性和可维护性降低,特别是在大型程序中。而闭包将局部变量作为离散单元捆绑到函数对象中,保持其状态,并且该状态不能被外部访问和修改。这样可以避免全局变量带来的问题,更安全和稳定。
求最佳答案{:10_254:}
页:
[1]