|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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”,如果全局变量不适用或者不能满足需求时,闭包可以作为一种稳定而且安全的选择。闭包可以将需要隐藏的信息封装在内部函数内部,防止被外界访问和修改,从而提高代码的安全性。
|
|