Python之闭包

最近要使用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销毁时,内部持有的闭包变量才会销毁。

你可能感兴趣的:(python)