1.python中,對(duì)象賦值實(shí)際是對(duì)對(duì)象的引用,比如:
alist=[1,2,[1,2,3]]
b=alist
其中,b就是直接引用**ist指向的對(duì)象,也就是內(nèi)存中heap中的一個(gè)值,以后這個(gè)值發(fā)生了什么變化,b和alist就跟著變化
2.淺拷貝--copy,直接看例子:可以看到,淺拷貝只拷貝父對(duì)象,不會(huì)拷貝對(duì)象內(nèi)部的子對(duì)象。我不是很理解這句話,其實(shí)就是淺拷貝如果
里面是具體的值,則拷貝的對(duì)象不會(huì)變化,如果是拷貝的是堆對(duì)象,則跟著堆對(duì)象的變化而變化?
l=[1,2,[1,2,3]]
>>>m=copy.copy(l)
>>>m
[1,2,[1,2,3]]
>>>l[2].append(4)
>>>l
[1,2,[1,2,3,4]]
>>>m
[1,2,[1,2,3,4]]
>>>l[0]=100
>>>l
[100,2,[1,2,3,4]]
>>>m
[1,2,[1,2,3,4]]
現(xiàn)在依次把m,l中的值地址打印出來(lái):
[id(x)forxinm]
[35289464L,35289440L,55546952L]
>>>[id(x)forxinl]
[35291072L,35289440L,55546952L]
可以看到末端的列表元素指向的是同一個(gè)地址,所以這個(gè)地址里的東西發(fā)生變化了,就都會(huì)變化呀
再舉一例:
>>>l=[1,2,{'age':90}]
>>>l
[1,2,{'age':90}]
>>>m=copy.copy(l)
>>>m
[1,2,{'age':90}]
>>>[id(x)forxinl]
[35289464L,35289440L,55566680L]
>>>[id(x)forxinm]
[35289464L,35289440L,55566680L]
>>>l[2]=[1,2]
>>>l
[1,2,[1,2]]
>>>m
[1,2,{'age':90}]
>>>[id(x)forxinl]
[35289464L,35289440L,55548552L]
3.深拷貝:直接就是拷貝了對(duì)象本身,即堆內(nèi)存中的那一坨,那你原來(lái)那一坨的改變就不能影響深拷貝的元素的變化了
>>>mimi=['mimi',['age',30]]
>>>kiki=copy.deepcopy(mimi)
>>>bibi=copy.deepcopy(mimi)
>>>printid(mimi),id(kiki),id(bibi)
555754965554733655546248
>>>kiki
['mimi',['age',30]]
>>>bibi
['mimi',['age',30]]
>>>kiki[0]='kiki'
>>>bibi[0]='bibi'
>>>printmimi,kiki,bibi
['mimi',['age',30]]['kiki',['age',30]]['bibi',['age',30]]
>>>kiki[1][1]=31
>>>kiki
['kiki',['age',31]]
>>>bibi[1][1]=32
>>>printmimi,kiki,bibi
['mimi',['age',30]]['kiki',['age',31]]['bibi',['age',32]]
>>>[id(x)forxinmimi]
[53922472L,55631304L]
>>>[id(x)forxinmimi]
[53922472L,55631304L]
>>>[id(x)forxinkiki]
[56337952L,55546760L]
>>>[id(x)forxinbibi]
[53923752L,55600264L]
從例子看出,深拷貝就不會(huì)列表中的列表發(fā)生一起改變的事情,
總結(jié)一下:
1.利用切片和工廠方法,copy方法進(jìn)行的拷貝都是淺拷貝,就是拷貝的是原有對(duì)象的地址,在這個(gè)地址上發(fā)生的改變之后都被記下來(lái),
切片復(fù)制:
p=[1,2,3]
t=p[:]
工廠方法:
t=list(p)
copy方法:
t=copy.copy(p)
2.利用copy中的deepcopy方法進(jìn)行拷貝就叫做深拷貝,外圍和內(nèi)部元素都進(jìn)行了拷貝對(duì)象本身,而不是引用。就是把所有的值復(fù)制了一遍,
原有地址的變化和拷貝發(fā)生后的對(duì)象毫無(wú)關(guān)聯(lián)
注意的是:對(duì)于數(shù)字,字符串,其他原子類型的對(duì)象來(lái)說(shuō),沒有拷貝的說(shuō)法,原子類型對(duì)象:個(gè)人感覺就是存放在棧中的對(duì)象,顧名思義
就是不可再分割,或是組成其它數(shù)據(jù)類型的元元素。python來(lái)說(shuō)就是數(shù)字,字符串
以上內(nèi)容為大家介紹了python的深淺拷貝,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.fengjieshuijing.cn/