鱼C论坛

 找回密码
 立即注册
查看: 2040|回复: 7

[已解决]python练习第20讲第六题

[复制链接]
发表于 2020-10-16 21:48:40 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
def funX():
    x = 5
    def funY():
        nonlocal x
        x += 1
        return x
    return funY

a = funX()
print(a())
print(a())
print(a())
我明白不断地调用a()实际是就是在调用funY(),得到funY()的返回值,只是不明白在第二次调用a()的时候,这个函数的x值是从哪里得到的呢?第一次是我的理解是从funX()的第一行代码中获得的,但第二次调用a()的时候并不会调用funX()啊,那么它的x值是从哪儿获得的呢?麻烦大佬可以解答一下,谢谢了!
最佳答案
2020-10-16 22:10:35
最爱你小海海 发表于 2020-10-16 22:05
大佬,但是在这个调用过程中难道不需要一个传入x值的过程吗?还是说因为nonlocal关键字的原因,在继续调用Y ...

官方这样说的
当内嵌函数引用了包含它的函数(enclosing function)中的non-local 变量后,这些变量会被保存在enclosing function的__closure__属性中,成为enclosing function本身的一部分;也就是说,这些变量的生命周期会和enclosing function一样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-16 22:00:06 | 显示全部楼层
函数包括了它声明时的上下文 只要你的a还在 x就不会消失 至于x在哪嘛
print(a.__closure__[0].cell_contents)
就是
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-16 22:05:49 | 显示全部楼层
大佬,但是在这个调用过程中难道不需要一个传入x值的过程吗?还是说因为nonlocal关键字的原因,在继续调用Y函数的时候就会把x的值自动获取。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-16 22:10:35 | 显示全部楼层    本楼为最佳答案   
最爱你小海海 发表于 2020-10-16 22:05
大佬,但是在这个调用过程中难道不需要一个传入x值的过程吗?还是说因为nonlocal关键字的原因,在继续调用Y ...

官方这样说的
当内嵌函数引用了包含它的函数(enclosing function)中的non-local 变量后,这些变量会被保存在enclosing function的__closure__属性中,成为enclosing function本身的一部分;也就是说,这些变量的生命周期会和enclosing function一样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-16 22:16:20 | 显示全部楼层
kogawananari 发表于 2020-10-16 22:10
官方这样说的
当内嵌函数引用了包含它的函数(enclosing function)中的non-local 变量后,这些变量会被 ...

好的,大佬,那我的理解和官方的意思其实是差不多的吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-16 22:19:25 | 显示全部楼层
最爱你小海海 发表于 2020-10-16 22:16
好的,大佬,那我的理解和官方的意思其实是差不多的吧

主要是如果你有了俩
a = funX()
b = funX()
a和b有各自的__closure__属性 互不影响
只有第一次是取的同一个x
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-16 23:03:42 | 显示全部楼层
def funX():
    x = 5
    def funY():
        nonlocal x
        x += 1
        return x
    return funY

a = funX()  #本行代码执行后,a = funy,是一个函数对象,没有括号说明a的赋值不是funy函数对象的返回值
print(a())    #本行代码执行的是print(funy()),也就是打印funy() 的返回值,此时X初始值为非局部变量,因此x初始值为5,运算后为6,
                 #     funy() 的返回值为6,打印6。后7、8同
print(a())
print(a())
======================可以加代码验证分析结果是否正确==================
def funX():
    x = 5
    def funY():
        nonlocal x
        x += 1
        return x
    return funY

a = funX()
print(type(a))         
print(type(funX()))
=========运行结果==========
<class 'function'>                  #a的打印结果
<class 'function'>                  #funX()函数返回值的打印结果
>>> a
<function funX.<locals>.funY at 0x031970B8>   #这里已经很能说明问题了
>>>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-17 10:21:42 | 显示全部楼层
笨鸟学飞 发表于 2020-10-16 23:03
def funX():
    x = 5
    def funY():

谢谢大佬的回复
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-18 07:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表