求教:运行顺序
def count(): fs = [] for i in range(1, 4): def f(j): def g(): return j*j return g r = f(i) fs.append(r) return fs f1, f2, f3 = count() print f1(), f2(), f3()
def count(): fs = [] for i in range(1, 4): def f(j): def g(): return j*j return g r = f(i) fs.append(r) return fs f1, f2, f3 = count() print f1(), f2(), f3()
2017-08-11
在练习中
运行一次count函数 会执行3次for循环
在每次for循环中会向fs这个list中插入一个值(append(f(i)))而不是返回整个fs
而函数的最后返回的fs是一个list 里面有3个值 因为里面的值是在for循环时就添加的所以是1,4,9
在讲解的例子中,每次for循环添加的并不是一个list的值而是一个指向函数的指针(append(f))所以三个for循环结束以后返回的是三个地址指针,函数并不会执行,而且三次for循环后i已经变成了3
f1, f2, f3 = count()等价于f1=count()[0],f2=count()[1],f3=count()[2]
他们指向的都是内存地址 所以你如果直接输出print f1,f2,f3得到的就会是3个内存地址
如果你输出print f1(),f2(),f3()的话 这时候才会去执行函数,而这个时候这个函数的i的值已经是等于3了 所以结果会是3个9
这个闭包中,引用的局部变量在返回后发生了变化才造成了这个结果(i从1变成了3)所以在引闭包时要豹子引用的局部变量在函数返回后不能发生变化
虽然我觉得犯这种错误要比不犯错难多了,这个例子更像为了举例而举例
举报