首页 >后端开发 >Python教程 >为什么 Python 2 的列表解析会在其范围之外重新绑定名称?

为什么 Python 2 的列表解析会在其范围之外重新绑定名称?

Patricia Arquette
Patricia Arquette原创
2024-11-29 12:41:10435浏览

Why Does Python 2's List Comprehension Rebind Names Outside Its Scope?

列表推导式的意外行为:反弹名称和模糊范围

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn