首页  >  文章  >  后端开发  >  为什么`x = [4]`修改`x`但`x = x [4]`在Python中创建一个新列表?

为什么`x = [4]`修改`x`但`x = x [4]`在Python中创建一个新列表?

Susan Sarandon
Susan Sarandon原创
2024-10-30 02:09:03823浏览

Why Does `x  = [4]` Modify `x` but `x = x   [4]` Create a New List in Python?

不同的行为:list.__iadd__ 与 list.__add__

考虑以下神秘的 Python 代码:

x = y = [1, 2, 3, 4]
x += [4]
print(x)  # [1, 2, 3, 4, 4]
print(y)  # [1, 2, 3, 4, 4]

现在,将其与以下代码片段并置:

x = y = [1, 2, 3, 4]
x = x + [4]
print(x)  # [1, 2, 3, 4, 4]
print(y)  # [1, 2, 3, 4]

令我们困惑的是它们行为上的明显差异。为什么 x = [4] 会改变原始列表 x,而 x = x [4] 会产生一个新列表?

答案在于 Python 的对象方法。 list.__iadd__ 通过将第二个列表的元素附加到现有列表上来改变现有列表。相反,list.__add__ 创建一个包含两个输入列表的元素的新列表。

像 x = y 这样的表达式首先尝试调用 __iadd__。如果 __iadd__ 可用,它将执行这个突变魔法。否则,它将默认为 __add__,它创建一个新列表并将其分配给 x。由于列表类定义了 __iadd__,第一个代码片段改变了原始的 x 列表,而后一个代码片段创建了一个新列表并将其分配给 x,而 y 保持不变。

以上是为什么`x = [4]`修改`x`但`x = x [4]`在Python中创建一个新列表?的详细内容。更多信息请关注PHP中文网其他相关文章!

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