繁体   English   中英

Python中列表的内存管理

[英]Memory management of lists in Python

我似乎无法理解python中的以下行为:

x = [0, [1,2,3,4,5],[6]]
y = list(x)
y[0] = 10
y[2][0] = 7
print x
print y

它输出:

[0, [1, 2, 3, 4, 5], [7]]
[10, [1, 2, 3, 4, 5], [7]]

为什么x和y的第二个索引更新,只有y的第一个索引?

发生这种情况是因为list(x)创建了列表x浅表副本。 x中的一些元素本身就是列表。 没有为他们创建副本; 它们作为参考传递。 以这种方式, xy最终具有与元素相同的列表的引用。

如果要创建x的深层副本 (即也要复制子列表),请使用:

import copy
y = copy.deepcopy(x)

在Python中,序列被分为可变序列,可以在创建之后进行更改,以及不可变序列。对于不可变序列(字符串,Unicode,元组),Python为它们制作副本。对于可变序列(列表,字节数组) ,Python为它们提供了参考。

因此,如果您更改x,y也将更改,因为它们具有对同一列表的引用。

标准类型层次结构

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM