在python中,可以再函数的内部再定义函数,比如:
def A():
print 'A()***'
def B():
print 'B()***'
return B
B函数只能在A的内部访问,这样可以防止其他代码访问函数B。特别的,在函数B中也可以引用A中的变量:
def A(lst):
print 'A()***'
def B():
print 'B()***'
return sum(lst)
return B
在python中,像这种内层函数引用了外层函数的变量(参数也算变量),然后返回内层函数的情况,称为闭包(Closure)。闭包的特点是:返回的函数引用了外层函数的局部变量,在使用闭包的时候要特别注意的一点就是:要确保引用的局部变量在函数返回后不能再发生改变。比如:
def f():
flist = []
for i in range(1,5):
def g():
return i*i
flist.append(g)
return flist
list = f()
for i in list:
print i()
这段代码的输出为:
原因就是当f()函数仅返回了4个g()函数的引用,并没有执行这4个函数。当对list中每一个函数引用进行调用时才执行i*i,所引用的变量 i 的值已经变成了4。所以返回的只有4*4的值。
因此,在返回函数不要引用任何循环变量,或者后续会发生变化的变量,否则可能会出现和预想不一致的结果。
如果要输出1*1,2*2,3*3,4*4,下面提供一种思路:
def count():
fs = []
for i in range(1, 5):
def f(j):
def g():
return j*j
return g
r = f(i)
fs.append(r)
return fs
list = count()
for f in list:
print f()