python中的闭包

一、定义

python中的闭包从表现形式上定义为:如果在一个内部函数里,对在外部作用域(但不是在全局作用域)的变量进行引用,那么内部函数就被认为闭包,这个定义是相对直白的,好理解的。

def demo():
    x=10
    def demo1(y):
        return x+y
    return demo1
c=demo()
d=c(6)
print(d)

结合这段简单的代码和定义来说明闭包:
如果在一个内部函数里:demo1(y)就是这个内部函数,
对在外部作用域(但不是在全局作用域)的变量进行引用:x就是被引用的变量,x在外部作用域demo()函数里面,但不在全局作用域里,
则这个内部函数demo1就是一个闭包。

再稍微讲究一点的解释是,闭包=函数块+定义函数时的环境,adder就是函数块,x就是环境,当然这个环境可以有很多,不止一个简单的x。

二、使用闭包注意事项

1、闭包中是不能修改外部作用域的局部变量的

def foo():
    m=0
    def foo1():
        m=1
        print(m)

    print(m)
    foo1()

foo()

输出0、1

从执行结果可以看出,虽然在闭包里面也定义了一个变量m,但是其不会改变外部函数中的局部变量m。

2、以下这段代码是在python中使用闭包时一段经典的错误代码

def fun():
    a = 1
    def fun1():
        a = a + 1
        return a
    return fun1

result=fun()
data=result()
print(data)

输出:

Traceback (most recent call last):
  File "D:\Integrated_platform\vehicle_pool_for_sale_pytest\123.py", line 151, in <module>
    data=result()
  File "D:\Integrated_platform\vehicle_pool_for_sale_pytest\123.py", line 146, in fun1
    a+=1
UnboundLocalError: local variable 'a' referenced before assignment

如果在一个范围内,对一个变量进行赋值,那么这个变量就会被认为是局部变量,就像在func()这个函数范围之内,我们对a这个变量进行了重新赋值:a+=1,那么编译器就会认为a这个变量是一个局部变量,而这个赋值表达式实际上是从右向左进行的,也就是说,在进行a+1运算的时候,a并没有被定义,所以就爆出了这个UnboundLocalError错误。

解决:

def fun():
    a=1
    def fun1():
        nonlocal a
        a+=1
        return a
    return fun1

result=fun()
data=result()
print(data)

三、使用场景(后面的文章会详细讲解)

1、做数据锁定

2、实现装饰器

在这里插入图片描述

  • 17
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 26
    评论
评论 26
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敲代码敲到头发茂密

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值