闭包简介实现方式
在函数内部调用函数在函数内部 返回函数名称 globalnonlocal参考
闭包简介闭包的实质就是函数的嵌套定义,就是在函数的内部在定义函数。
使用闭包能够避免 函数内部的局部变量随着函数的调用结束而摧毁,因此使用闭包能够记录函数内局部变量的信息。
闭包常常用在游戏中记录人物的移动位置,通过调用相关函数,实现游戏中人物的移动。如果不用闭包,每一次调用函数,游戏中的人物都要从起始坐标开始移动,很显然,这是不合理的。
闭包有两种实现方式
在函数内部调用函数在函数内部 返回函数名称
通常我们将外部函数叫做装饰器
实现方式 在函数内部调用函数def fun(name):
num = 0
def fun2(x,y):
print(x,y)
fun2(0,0)
if __name__ == '__main__':
fun('xie') #通过调用fun(),进而调用其中的内部函数fun2,最后输出0 0
在函数内部 返回函数名称
def fun(name):
num = 0
def fun2(x,y):
print(x,y)
return fun2
if __name__ == '__main__':
maker = fun('xie') #调用包装器
maker(1,1) #调用内部函数
global
被 global 修饰的变量是全局变量,在函数内就可以修改变量的值
在下面的案例中,如果 num 没有 global 修饰,执行 fun2() 时就会报错,执行 fun1() 时不会报错。因为非全局变量在函数内部只能被读,不能被改写
global num = 1 def fun1(): result = num +10 def fun2(): num = num +10 if __name__ == "__main__": fun1() fun2()nonlocal
使用 nonlocal 关键字,可以在内部函数改变“外部变量”的值。
注意:nonlocal 是修饰内部函数的变量,而不像 global 修饰函数外的变量
def Maker(step): #包装器 num=1 def fun1(): #内部函数 nonlocal num #nonlocal关键字的作用和前面的local是一样的,如果不使用该关键字,则不能再内部函数改变“外部变量”的值 num=num+step #改变外部变量的值(如果只是访问外部变量,则不需要适用nonlocal) print(num) return fun1 j=1 func2=Maker(3) #调用外部包装器 while(j<5): func2() #调用内部函数4次 输出的结果是 4、7、10、13 j+=1参考
链接: Python中的闭包到底有什么用.



