好吃的小笼包 发表于 2020-6-29 17:07:24

python列表

>>> list1 =
>>> list2 = list1[:]
>>> list2

>>> list3 = list1
>>> list3

>>> list1.sort()
>>> list1

>>> list2

>>> list3



>>> old =
>>> new = old
>>> old =
>>> print(new)


这两段代码有什么不同,为什么第一段代码里list3会跟着list1一起变化,而第二段代码的new不会跟着old变化?

Twilight6 发表于 2020-6-29 17:09:16



直接分析下面的 old 和 new 的,你就会了解为什么了,这是我之前回答同样的问题的答案,你有的时候问问题前可以先去用用论坛的搜索功能哈~~~{:10_281:}

old =    #第一次赋值
new = old    #将old 赋值给new   这行代码就等价与new =
old =    #这里你的old重新赋值,就会覆盖原本的old 变量,但是new 来源还是
print(new)

你可以这样做
old =
new = old          #他们的根本来源都是
new.append(6)

print(old)



同理:
old =
new = old          #他们的根本来源都是
old.append(6)
print(new)



python中 变量都有id (通俗说就是来源,id(new)可以查询new的id)

id相同 他们就相当于捆绑在一起了   其中一个改变 另一个也会随之改变就像   量子纠缠

而你后面是 old = 是重新给old 赋值 python 就会重新赋予他一个id    就和先前的id 不同 new id 还是原来的old = 时候的id

而 copy 也就是浅拷贝,相当于只拷贝列表本身,但是内部的可变元素并没有与之拷贝成新的

同理 列表的大部分方法(如 romove、pop、insert、append、sort等)都是在原列表上进行改变的,只改变本源,导致与其相关的都一起发生改变



好吃的小笼包 发表于 2020-6-29 21:19:12

意思是说第一段代码中的list1只是进行了重排序,而id没有改变,所以list1和list3的id依然相同,所以他俩会一起变化,而第二段代码由于对old重新赋值,导致old的id变化,而new的id没有变,所以print(new)依然会输出旧的id的结果。是这个意思吗?

yhhpf 发表于 2020-6-29 21:33:24

好吃的小笼包 发表于 2020-6-29 21:19
意思是说第一段代码中的list1只是进行了重排序,而id没有改变,所以list1和list3的id依然相同,所以他俩会 ...

嗯嗯,老兄理解能力可以,差不多这意思,实际走一走看结果~

>>> #:
>>> old =
>>> new = old         #赋值

>>> print(id(new))   #查看new的内存地址,你可以理解为这个返回的ID是用来判断这个对象的唯一值
2612641471432

>>> print(id(old))      #这里可以和上面做对比,可以发现和new的ID是一致的。
2612641471432

>>> old =          #给OLD重新赋值

>>> print(id(new))    #此时NEW的ID并未做调整
2612641471432

>>> print(id(old))   #而OLD的ID已经变更了
2612641794376

>>> #做对比:
>>> old =   
>>> new = old

>>> print(id(new))
2612641564744

>>> print(id(old))
2612641564744

>>> old.append(6)   #这里不采取赋值的方式,而是用append给old增加元素

>>> print(id(new))
2612641564744

>>> print(id(old))      #对比可以发现,通过append增加元素的,并不会改变ID。
2612641564744

>>> print(new)

好吃的小笼包 发表于 2020-6-29 21:59:17

嘿!怎么又是你{:10_277:}这次给你最佳答案吧
页: [1]
查看完整版本: python列表