如何正确的使用Python函数


本文主要讲述Python函数的问题,怎样创建Python函数等问题,这些内容都是一些门户网站和技术论坛找到的,中间可能有不少错误是我没有挑出的,欢迎大家指正。

语法上看比较简单,但是用处却是相当广泛的。在Python 2.1版本以前,只有全局域和局部作用域,而在2.1以后的版本中我们可以使用静态嵌套域,如像下面这样的嵌套函数中,在以前,内部函数是不能访问外部Python函数作用域中的变量。

PyDev 选项窗口

在Python 2.1版本以前,只有全局域和局部作用域,而在2.1以后的版本中我们可以使用静态嵌套域,如像下面这样的嵌套Python函数中,在以前,内部Python函数是不能访问外部函数作用域中的变量的,def foo():

  1. def foo():  
  2.     m = 3 
  3.     def bar():  
  4.         n = 4 
  5.         print m + n  
  6.     print m  
  7.  bar() 

而在现在的版本中可以完美运行,而bar()中的 m 就是一个既不属于全局域又不属于局部域的闭包变量,它存活在一个Python函数的名称空间和作用域---嵌套作用域。而在闭包中对嵌套作用域中的访问规则与上面讨论的Global是一样的。即在对闭包变量 m 的重新声明之前引用 m 都会引发异常。

为什么会这样呢?其实是因为m的类型有关,我们知道Pyhton中的基本数据类型分为可变和不可变,对于不可变类型的赋值,其实是重新定义一个新的变量对象。并深拷贝原对象到新对象,参考str类型说明。 如果将上面的 m 声明成可变类型list,那就不会产生这个异常了。

关于可变类型与不可变类型的说明,这里就不展开说了,大家可以看API Document下面举一个闭包的实际例子:

  1. def hellocounter (name):  
  2.     count=[0]  
  3.     def counter():  
  4.         count[0]+=1  
  5.         print 'Hello,',name,',',str(count[0])+' access!'  
  6.     return counter  
  7.  
  8. hello = hellocounter('ysisl')  
  9. hello()  
  10. hello()  
  11. hello()  
  12.  
  13. Console output:   
  14.  Hello, ysisl , 1 access!  
  15.  Hello, ysisl , 2 access!  
  16.  Hello, ysisl , 3 access!  
  1. 如何使Python嵌入C++应用程序?
  2. 深入探讨Ruby与Python语法比较
  3. Python学习资料介绍分享
  4. Python学习经验谈:版本、IDE选择及编码解决方案
  5. 浅析Python的GIL和线程安全

评论关闭