>>>[5, 9, -12, -21, 36]
闭包:在外部函数中定义了一个内部函数,内部函数可以引用外部函数的参数和变量,
当外部函数返回时,可以返回内部函数,并且相关参数和变量都保存在返回的函数中了。每次调用都会返回一个新的函数,即使传入相同的参数
另一个需要注意的问题是,返回的函数并没有立刻执行,而是直到调用了f()(内部函数)才执行
返回闭包时牢记的一点就是:返回函数不要引用任何循环变量,或者后续会发生变化的变量(下个例子的i)
实例:#coding:utf-8
def count():
fs=[]
for i in range(1,4):
def f():
return i * i
fs.append(f)
print fs,i
return fs
f1,f2,f3=count() #==========>>>f1,f2,f3分别对应[]的第一项,第二项,第三项
print f1,f2,f3 #===========>>打印的是f1函数的内存地址
print f1(),f2(),f3()#========>> f1()调用了函数f(),他的参数是for循环的最后一次的值
匿名函数==lambda函数,格式:lambda x:x*x
装饰器函数=====在代码运行期间动态增加功能的方式,称之为“装饰器”(Decorator)也是高阶函数
装饰器函数格式:首先定义函数,然后在定义另一个函数之前,加上@函数。实例
:def log(func):
return
@log
def now():
print ("ok")
调用now()函数,相当于调用 now=log(now)
由于log()是一个decorator,返回一个函数,所以,原来的now()函数仍然存在,只是现在同名的now变量指向了新的函数,于是调用now()将执行新函数,即在log()函数中返回的wrapper()函数。
wrapper()函数的参数定义是(*args, **kw),因此,wrapper()函数可以接受任意参数的调用。在wrapper()函数内,首先打印日志,再紧接着调用原始函数。