|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
>>> old = [1,2,3,4,5]
>>> new = old
>>> old = [6]
>>> print(new)
[1, 2, 3, 4, 5]
这里为什么new列表没有跟着old列表一起变化
>>> old = [1,2,3,4,5]
>>> new = old
>>> old.reverse()
>>> print(new)
[5, 4, 3, 2, 1]
这样new列表会跟着变是为什么
old = [1, 2, 3, 4, 5] #第一次赋值
new = old #将old 赋值给new 这行代码就等价与 new = [1,2,3,4,5]
old = [6] #这里你的old重新赋值,就会覆盖原本的old 变量,但是new 来源还是[1,2,3,4,5]
print(new)
你可以这样做old = [1,2,3,4,5]
new = old #他们的根本来源都是[1,2,3,4,5]
new.append(6)
print(old)
[1,2,3,4,5,6]
同理:old = [1,2,3,4,5]
new = old #他们的根本来源都是[1,2,3,4,5]
old.append(6)
print(new)
[1,2,3,4,5,6]
python中 变量都有id (通俗说就是来源,id(new)可以查询new的id)
id相同 他们就相当于捆绑在一起了 其中一个改变 另一个也会随之改变 就像 量子纠缠
而你后面是 old = [6] 是重新给old 赋值 python 就会重新赋予他一个id 就和先前的id 不同 new id 还是原来的old = [1,2,3,4,5] 时候的id
而 copy 也就是浅拷贝,相当于只拷贝列表本身,但是内部的可变元素并没有与之拷贝成新的
同理 列表的大部分方法(如 romove、pop、insert、append、sort等)都是在原列表上进行改变的,只改变本源,导致与其相关的都一起发生改变
|
|