列表问题求解?
>>> old =>>> new = old
>>> old =
>>> print(new)
新人求解,这不是在系统里生成了old的内存空间存放12345了吗,然后把new标签也指向old的这个内存,那old变成了6,为啥print(new)还是12345呀。{:10_266:}
你打印一下这两个变量的地址就知道了
print(id(old)) 变量只是个指向,后面的常量才是存储的地址。
old指向6的内存地址之后,12345还是被new指向着的。 本帖最后由 sunrise085 于 2020-6-24 08:36 编辑
两个列表是两个变量,old和new 是两个变量标签。前两行代码是把两个变量标签都贴在了 第一个列表 这个变量上了,第三行代码是把 old 撕下来贴在了另一个列表上了。而new没有动,所以print的时候,还是原来的列表
Python是给变量分配空间,而不是给标签分配空间。要与其他语言区分开,C语言是先有变量名,再有变量值,Python是先有变量值,再有变量标签。
可以看看我这个帖子
把昨天晚上的复制过来了哈哈~
前面 new = old 都是指 new 和 old 两个变量指向的是 同一个列表
可以这样理解,这两个都是列表 的别名
而你后来重新把 old = old 别名 给了列表 那么 列表就失去了 old 这个别名 只剩 new 这个别名
所以你打印 new 还是之前的列表
本帖最后由 jiong_jiong 于 2020-6-24 09:19 编辑
>>> old = 建立了一个数组,标签是old
>>> new = old 现在标签new 和标签old 都指向刚才的数组
>>> old = 标签old指向
>>> print(new) 标签new指向的数组没有变化,还是
这样是不是超级清楚了,请赏最佳,谢谢{:5_109:} {:5_109:} {:5_109:} 前面的前辈说的很好,我说点我个人的看法:
>>> old = #赋值给了old
>>> new = old # old赋值给new, 那么new =
>>> old = # 这里old被重新赋值, 但这跟new没有关系
>>> print(new) # 所以这里打印的new,就是之前赋值的 >>> #楼主的:
>>> 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)
---------------------------------------------------------------------------------------------------
对比可以发现,old=赋值操作是直接改变内存地址的,而之前通过new = old时已经把久的old内测地址给到了new,所以new没有跟着一起变。
而列表是属于可变类型对象,第二段代码用append去修改old时,内存地址没变化,所以new会跟着一起变; sunrise085 发表于 2020-6-24 08:34
两个列表是两个变量,old和new 是两个变量标签。前两行代码是把两个变量标签都贴在了 第一个列表 ...
老哥顺手让我提前学习了下深浅拷贝{:5_110:}
页:
[1]