本文主要讲述Python函数的问题,怎样创建Python函数等问题,这些内容都是一些门户网站和技术论坛找到的,中间可能有不少错误是我没有挑出的,欢迎大家指正。
语法上看比较简单,但是用处却是相当广泛的。在Python 2.1版本以前,只有全局域和局部作用域,而在2.1以后的版本中我们可以使用静态嵌套域,如像下面这样的嵌套函数中,在以前,内部函数是不能访问外部Python函数作用域中的变量。
在Python 2.1版本以前,只有全局域和局部作用域,而在2.1以后的版本中我们可以使用静态嵌套域,如像下面这样的嵌套Python函数中,在以前,内部Python函数是不能访问外部函数作用域中的变量的,def foo():
- def foo():
- m = 3
- def bar():
- n = 4
- print m + n
- print m
- bar()
而在现在的版本中可以***运行,而bar()中的 m 就是一个既不属于全局域又不属于局部域的闭包变量,它存活在一个Python函数的名称空间和作用域---嵌套作用域。而在闭包中对嵌套作用域中的访问规则与上面讨论的Global是一样的。即在对闭包变量 m 的重新声明之前引用 m 都会引发异常。
为什么会这样呢?其实是因为m的类型有关,我们知道Pyhton中的基本数据类型分为可变和不可变,对于不可变类型的赋值,其实是重新定义一个新的变量对象。并深拷贝原对象到新对象,参考str类型说明。 如果将上面的 m 声明成可变类型list,那就不会产生这个异常了。
关于可变类型与不可变类型的说明,这里就不展开说了,大家可以看API Document下面举一个闭包的实际例子:
- def hellocounter (name):
- count=[0]
- def counter():
- count[0]+=1
- print 'Hello,',name,',',str(count[0])+' access!'
- return counter
- hello = hellocounter('ysisl')
- hello()
- hello()
- hello()
- Console output:
- Hello, ysisl , 1 access!
- Hello, ysisl , 2 access!
- Hello, ysisl , 3 access!
【编辑推荐】