Python闭包是函数对象与外层局部变量生命周期绑定的必然现象,需满足内层函数引用外层局部变量、外层函数返回内层函数、变量在外层函数返回后仍被持有三个条件。Python闭包不是语法糖,也不是高级技巧------它是函数对象和变量生命周期绑定后必然出现的现象,只要满足三个条件就会自然产生。闭包的判定标准:closure 不为 None 且内层函数引用了外层局部变量很多人以为"嵌套函数"就是闭包,其实不是。关键看两点:一是内层函数是否真的用到了外层函数的局部变量(而非全局变量),二是这个变量在外层函数返回后依然被持有。def outer(): x = 10; return lambda: x → 是闭包,lambda 引用了 x,调用 outer() 返回的函数后,closure 非空def outer(): x = 10; return lambda: 10 → 不是闭包,lambda 没引用 x,closure 为 Nonedef outer(): return lambda: global_var → 不是闭包,引用的是全局变量,不捕获外层局部作用域验证方式很简单:fn = outer(); fn.closure 如果是 None,就不是闭包;否则里面每个 cell 对应一个被捕获的变量。为什么修改闭包变量会出错:Python 2.x 和 3.x 的 nonlocal 差异常见错误现象:UnboundLocalError: local variable 'x' referenced before assignment ------ 这不是 bug,是作用域规则在起作用。立即学习"Python免费学习笔记(深入)";在 Python 2.x 中,无法在闭包内修改外层变量,连 += 都会报错,只能读取Python 3.x 引入 nonlocal,但必须显式声明:nonlocal x 才能赋值;否则哪怕只写 x = x + 1,Python 就认定你在定义新局部变量,导致引用未赋值的 x注意:nonlocal 只能向上找一层或几层外层函数的局部变量,不能跳过一层去捕获更外层的,也不能指向全局变量示例:def make_counter(): count = 0; def inc(): nonlocal count; count += 1; return count; return inc ------ 没有 nonlocal 这行,inc() 第二次调用必报错。 Mokker AI AI产品图添加背景
相关推荐
ServBay15 小时前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队用户83562907805116 小时前
如何使用 Python 添加和管理 Excel 批注(完整示例)用户83562907805116 小时前
使用 Python 管理 Excel 工作表:创建、复制、删除与重命名SelectDB16 小时前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台这个DBA有点耶17 小时前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询掉头发的王富贵20 小时前
【StarRocks】极限十分钟入门StarRocksNturmoils20 小时前
WHERE 条件别凭习惯写,常用查询先跑一遍荣码1 天前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑用户8356290780512 天前
Python 操作 PDF 附件:添加、查看与管理指南Databend2 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路