Python进阶:对象复制与比较,分深浅,见真假
"==" 與 is
python 為 10 開辟內存空間, a與b同時指向這塊內存,即a與b的值相等,a與b的id也相等.因此 a==b 與 a is b 都返回True:
a = 10 b = 10 print(a == b) #True print(id(a)) #140726165951808 print(id(b)) #140726165951808 print(a is b) #True在[-5,256]范圍內的整數會有上面代碼的性能優化,而不在這范圍內的數字就會重新開辟內存空間。
【實驗證明,下面代碼只在終端中執行Python命令行時才有效,而在執行腳本時整型的數據都會分配同一個空間】
元組雖是不可變類型,但如果嵌套了可變類型(list),那么元組就變成是可變的了
t1 = (1, 2, [3, 4]) t2 = (1, 2, [3, 4]) print(t1 == t2) #Truet1[-1].append(5) print(t1 == t2) #False淺拷貝(shallow copy) 與 深拷貝(deep copy)
淺拷貝
使用數據類型本身的構造器,是淺拷貝
''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:857662006 尋找有志同道合的小伙伴, 互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' l1 = [1, 2, 3] l2 = list(l1) #l2 #[1, 2, 3]print(l1 == l2) #True print(l1 is l2) #Falses1 = set([1, 2, 3]) s2 = set(s1) #s2 #{1, 2, 3}print(s1 == s2) #True print(s1 is s2) #False切片也是淺拷貝
l1 = [1, 2, 3] l2 = l1[:]print(l1 == l2) #True print(l1 is l2) #Falsecopy.copy()淺拷貝
import copy l1 = [1, 2, 3] l2 = copy.copy(l1) print(l1 is l2) #False對于元組,這些操作都是返回指向同一元組(1,2,3)的引用
''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:857662006 尋找有志同道合的小伙伴, 互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' import copy t1 = (1, 2, 3) #t2 = tuple(t1) #t2 = t1[:] #t2 = copy.copy(t1) t2 = copy.deepcopy(t1) #如果元組中不只是原子類型,比如有list,dict就可以用deepcopyprint(t1 == t2) #Trueprint(t1 is t2) #True以下代碼 l2 = list(l1)表示 l2 指向 l1淺拷貝生成的新對象, 而對象中的元素,淺拷貝就只會使用原始元素的引用(內存地址)
l1 = [[1, 2], (30, 40)] l2 = list(l1)由于l1與l2是兩個指向不同的對象,所以 l1指向的列表增加元素不會改變 l2指向的列表
''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:857662006 尋找有志同道合的小伙伴, 互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' l1.append(100) print(l1) #[[1, 2, 3], (30, 40), 100] print(l2) #[[1, 2, 3], (30, 40)]由于淺拷貝對象中的元素是引用原始元素的內存地址,因此對于可變類型(list)增加了3,l2與l1中list的是同一個引用,因此也是[1,2,3]
l1[0].append(3) print(l1) #[[1, 2, 3], (30, 40), 100] print(l2) #[[1, 2, 3], (30, 40)]由于 tuple是不可變類型,因此修改后l1指向重新分配的一個新元組的引用。
''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:857662006 尋找有志同道合的小伙伴, 互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' l1[1] += (50, 60) print(l1) #[[1, 2, 3], (30, 40, 50, 60), 100] print(l2) #[[1, 2, 3], (30, 40)]深拷貝
拷貝出來的新對象完全獨立于原對象,修改操作與原對象互不影響
import copy x = [1] x.append(x) print(x) # [1, [...]]y = copy.deepcopy(x) print(y) # [1, [...]] print(x is y) #False print(x == y) #RecursionError: maximum recursion depth exceeded in comparison 遞歸錯誤 與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的Python进阶:对象复制与比较,分深浅,见真假的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python:值传递,引用传递?不存在的
- 下一篇: Python基础教程:用模块化来搭项目