最爱你小海海 发表于 2020-10-16 21:48:40

python练习第20讲第六题

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值是从哪儿获得的呢?麻烦大佬可以解答一下,谢谢了!

kogawananari 发表于 2020-10-16 22:00:06

函数包括了它声明时的上下文 只要你的a还在 x就不会消失 至于x在哪嘛
print(a.__closure__.cell_contents)
就是

最爱你小海海 发表于 2020-10-16 22:05:49

大佬,但是在这个调用过程中难道不需要一个传入x值的过程吗?还是说因为nonlocal关键字的原因,在继续调用Y函数的时候就会把x的值自动获取。

kogawananari 发表于 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一样

最爱你小海海 发表于 2020-10-16 22:16:20

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

好的,大佬,那我的理解和官方的意思其实是差不多的吧

kogawananari 发表于 2020-10-16 22:19:25

最爱你小海海 发表于 2020-10-16 22:16
好的,大佬,那我的理解和官方的意思其实是差不多的吧

主要是如果你有了俩
a = funX()
b = funX()
a和b有各自的__closure__属性 互不影响
只有第一次是取的同一个x

笨鸟学飞 发表于 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>   #这里已经很能说明问题了
>>>

最爱你小海海 发表于 2020-10-17 10:21:42

笨鸟学飞 发表于 2020-10-16 23:03
def funX():
    x = 5
    def funY():


谢谢大佬的回复
页: [1]
查看完整版本: python练习第20讲第六题