當你a=1000的時候a指向一個新的類,內容為1000,而b仍然指向原來指向的內容,因為你沒有叫它指向其他內容。你使用=符號,使得a和b指向同一個內容,而copy則是將b的內容復制后讓c指向這個拷貝的內容上了。看下面圖種運行的結果。b=a,使用a改變"age",b和a中的都改變了。而c采用copy,不受影響。
等會兒畫個圖補充上來就更容易理解了。
C從來沒有改變過。c中age的值一直保持在copy時獲得的那個10,只有a和b在后面age變成了11。
這個是個淺拷貝的事例,下面舉個深拷貝的事例,並結合淺拷貝,
c采用淺拷貝,d采用深拷貝,修改a中age的值,a和b的都改變了,c和d的沒有改變,但是修改a中“d”里的list,則導致abc中list都改變,d中是深拷貝的則沒有改變。
詳細看最下補充的圖:
a = {"d": ["a", "1"], "age": 10} b = a c = a.copy() from copy import deepcopy d = deepcopy(a) print "before:" print "a:", a print "b:", b print "c:", c print "d:", d a["d"].append("c") a["age"] = 11 print "after:" print "a:", a print "b:", b print "c:", c print "d:", d #=>結果 before: a: {'age': 10, 'd': ['a', '1']} b: {'age': 10, 'd': ['a', '1']} c: {'age': 10, 'd': ['a', '1']} d: {'age': 10, 'd': ['a', '1']} after: a: {'age': 11, 'd': ['a', '1', 'c']} b: {'age': 11, 'd': ['a', '1', 'c']} c: {'age': 10, 'd': ['a', '1', 'c']} d: {'age': 10, 'd': ['a', '1']}
ython中的對象之間賦值時是按引用傳遞的,如果需要拷貝對象,需要使用標准庫中的copy模塊。
1. copy.copy 淺拷貝 只拷貝父對象,不會拷貝對象的內部的子對象。
2. copy.deepcopy 深拷貝 拷貝對象及其子對象
一個很好的例子:
import copy a = [1, 2, 3, 4, ['a', 'b']] #原始對象 b = a #賦值,傳對象的引用 c = copy.copy(a) #對象拷貝,淺拷貝 d = copy.deepcopy(a) #對象拷貝,深拷貝 a.append(5) #修改對象a a[4].append('c') #修改對象a中的['a', 'b']數組對象 print 'a = ', a print 'b = ', b print 'c = ', c print 'd = ', d
輸出結果:
a = [1, 2, 3, 4, ['a', 'b', 'c'], 5]
b = [1, 2, 3, 4, ['a', 'b', 'c'], 5]
c = [1, 2, 3, 4, ['a', 'b', 'c']]
d = [1, 2, 3, 4, ['a', 'b']]