1.赋值操作,最容易想到的就是赋值操作
lst1=[1,2,3]
lst2=lst1
lst2.append(4)
print(lst2,lst1)
#输出结果[1, 2, 3, 4] [1, 2, 3, 4]
可以看到对lst2进行修改,lst1也变了,这是为什么吗呢?
因为python一切传递都是传引用
此时lst2,lst1都将指向同一个列表对象,如下图
此时,在
lst2
中所做的修改将反映在lst1 中,反之,在lst1上做的修改。
2.使用copy操作
lst1=[1,2,3]
lst2=lst1.copy()
lst2.append(4)
print(lst1,lst2)
#输出结果[1, 2, 3] [1, 2, 3, 4]
此时lst1 和
lst2
指向内存中不同的列表对象。由于二者指向内存不同,所以此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
3.使用list()
lst1=[1,2,3]
lst2=list(lst1)
lst2.append(4)
print(lst1,lst2)
#输出结果[1, 2, 3] [1, 2, 3, 4]
此时lst1 和
lst2
指向内存中不同的列表对象。由于二者指向内存不同,所以此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
4.使用索引,切片
lst1=[1,2,3]
lst2=lst1[:]
lst2.append(4)
print(lst1,lst2)
#输出结果[1, 2, 3] [1, 2, 3, 4]
如果我们使用
lst1[:]
,它将从头到尾对lst1进行切片,并返回列表的副本。此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
5.列表生成式
lst1=[1,2,3]
lst2=[i for i in lst1]
lst2.append(4)
print(lst1,lst2)
#输出结果[1, 2, 3] [1, 2, 3, 4]
此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
总结
- 使用赋值操作,此时两个列表将指向同一个列表对象
- 使用索引,列表构造函数,列表生成式,copy()等方式时,两个列表将指向不同的列表对象。