列表推导式的意外行为:反弹名称和模糊范围
Python 的列表推导式提供了一种简洁且便捷的方式来创建列表,但它们有一个隐藏的陷阱:重新绑定名称甚至超出了理解本身的范围。在 Python 2 中,这种奇特的行为是令人沮丧和编程错误的根源。
考虑以下代码:
x = "original value" squares = [x**2 for x in range(5)] print(x) # Prints 4 in Python 2!
在 Python 2 中,执行此代码将意外地打印 4 而不是“原值。”这是因为列表推导式将循环控制变量 x 泄漏到周围的作用域中,覆盖其原始值。
此行为源于列表推导式在 Python 2 中的实现方式:作为提高效率的优化。然而,这一直是 Python 程序员的一个重大痛点,导致错误和混乱。
值得庆幸的是,在 Python 3 中,这个“肮脏的小秘密”被消除了。列表推导式现在采用与生成器表达式相同的实现策略,即使用单独的执行框架。因此,在 Python 3 中,上面的代码片段按照预期正确打印了“原始值”,因为推导式中的 x 不会掩盖周围范围中的 x。
Guido van Rossum,Python 的创建者,解释了此更改背后的原因:
“[我们进行此更改]通过使用与以下相同的实现策略来修复列表理解的“肮脏的小秘密”生成器表达式。”
Python 3 中的这种改进行为证明了 Python 语言的持续开发和完善,确保了列表理解使用的清晰度和可预测性。
以上是为什么 Python 2 的列表解析会在其范围之外重新绑定名称?的详细内容。更多信息请关注PHP中文网其他相关文章!