python闭包函数 python闭包函数计数器只能用列表类型变量吗( 六 )


def count():
fs = []
for i in range(1, 4):
# 定义一个函数,等价于运行了 locals['f'] = 真正生成的函数
# 每次循环 , 这里都会重新生成一个函数,然后把重新生成的函数赋值给 locals['f']
def f():
return i * i# 引用了'i'这个名字,但并不是引用了'i'对应的值
# 等价于 locals['fs'].append(locals['f'])
# f 不是函数 , 它只是一个名字'f' 。f 引用的东西,也就是locals['f']才是真正的函数
fs.append(f)
# 于是这个for循环生成了三个函数,这三个函数是没有名字的,这个函数运行完后 , 它们跟'f'这个名字就毛关系都没有了(是的我说慌了,但可以先不管)
# 把整个列表返回,这个列表包含了三个函数
return fs
# count()返回三个函数的列表,unpack 列表的语法把列表中的三个函数抽出来,重新给他们命名为 f1, f2, f3
# 也就是说,
# locals['f1'] = 列表中的第1个函数
# locals['f2'] = 列表中的第2个函数
# locals['f3'] = 列表中的第3个函数
# 这三个函数跟'f'这个名字现在毛关系都没有 。(其实是有的 , 但为了说明需要简化,现在你可以完全不管括号里面说的话)
f1, f2, f3 = count()
print f1(), f2(), f3()
# 好了我们运行它们,输入都是 9
# def f():
#return i * i
这是因为 f1 现在对应的函数 , 里面引用了 'i' 这个字符串,我们根据 'i '这个字符串去找它对应的值,先找到 f 当前的locals字典,发现没有 , 因为函数定义的时候没有定义 i 变量 。然后再去closure['i']里面找,因为Python是通过closure字典实现闭包的(就当它是对的好不好) , 所以我们可以在closure['i']找到值,这个值就是我们上一次运行的时候count函数里面残留的locals['i'],而由于for循环三遍之后,locals['i'] == 3 , 所以找到 i 的值就是3 。所以最后输出都是9
python中使用闭包及修改外部函数的局部变量 在python中,函数可以被嵌套定义,也就是说,函数中可以定义函数 。该函数还可以将其内部定义的函数作为返回值返回 。
闭包的定义:一般来说,我们可以认为,如果一个函数可以读取其他函数中的局部变量,那么它们就构成了闭包 。
注意 :闭包的定义不是特别清晰 , 但大体上的意思是这样的 。
我们知道,普通的函数是可以使用全局变量的
类似的,函数中定义的函数 , 也是可以使用外部函数的变量的 。因此,满足了函数读取了其他函数局部变量的这一条件,他们因此构成了闭包 。
在闭包的使用中,我们可以先给外部的函数赋予不同的局部变量,然后再调用其中内部的函数时 , 就可以读取到这些不同的局部变量了 。
外部变量的使用 在普通函数中,虽然可以直接使用全局变量,但是不可以直接修改全局变量 。从变量的作用域来说,一旦你尝试修改全局变量,那么就会尝试创建并使用一个同名的局部变量 。因此,如果你需要在普通函数中修改全局变量 , 需要使用global
同样的,如果你希望通过定义在内部的函数去修改其外部函数的变量,那么必须使用nonlocal
python闭包函数的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于python闭包函数计数器只能用列表类型变量吗、python闭包函数的信息别忘了在本站进行查找喔 。

推荐阅读