分享

Python列表x+=y和x=x+y的区别

 nxhujiee 2023-04-26 发布于宁夏
x=[1,2]
print(id(x))
y=[3,4,5]
x+=y
print(id(x))

输出:

140664806054344
140664806054344

可见,x+=y是原位(inplace)修改,地址不变,相当于给x列表增加元素。因为+=调用iadd操作。+=和extend是一样的,列表的自带方法都是原位修改。

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

输出:

140713515751880
140713515753224

可见,x=x+y不是原位修改,地址会发生变化,毕竟相当于先生成[1,2,3,4,5]再赋值给x,x的地址变成了新的对象[1,2,3,4,5]的地址。因为+调用add操作,不支持原位修改。

如果希望使用+达到原位修改的目的,可以使用切片,相当于x的地址不变,将其中的每一个元素重新赋值:

x=[1,2]
print(id(x))
y=[3,4,5]
x[:]=x+y
print(id(x))

输出:

139973384829384
139973384829384

在不考虑id的情况下如何选择?
显然,原位修改+=会更快,但是副作用也很明显,那就是可能会无意修改和这个列表地址相同的列表。合并操作的速度更慢,因为要开辟一个新的列表,再把两个列表的元素拷贝进去。因此,在列表地址确保只有这个列表指向时,选择+=更合适。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多