最近要使用python,研究下闭包特性。
看下列的代码:
def counter(start_at = 0): count = [start_at] def incr(): count[0] += 1 return count[0] return incr if __name__ == '__main__': count = counter(5) print count() print count() count2 = counter(100) print count2() print count()
counter返回一个内部的函数,如果是别的语言,每次函数执行的结果应该是相同的,但是这里的运行结果是:
~/Documents/py python 1.py
6
7
101
8
显然,count和count2是两个相互独立的作用域。
python的作用域有两种,一是全局作用域,一个是局部作用域。
但是下面的代码:
def counter(start_at = 0): count = [start_at] def incr(): count[0] += 1 return count[0] return incr
如果只看第一行,那么count这个变量,生成于counter被调用,当函数调用结束时,count便销毁。
但是这里借助嵌套的函数incr,延长了count的声明周期。
这就形成了一种单独的作用域。
在上面的代码中,count和count2内部持有了一个count变量作为它的状态,所以count每次调用的结果是不同的。
当我们调用一次counter函数时,就产生了一个闭包函数,例如count,他的内部持有一个状态count。
所以上面的四次调用,产生了两个闭包函数。
当count和count2销毁时,内部持有的闭包变量才会销毁。