测试开发python面试_python测试开发面试之深浅拷贝
先來(lái)道題熱熱身
a = ('a', 'b','c')
c = copy.copy(a)
d = copy.deepcopy(a)
if c == d:
print("c和d的值相等")
if id(c) == id(d):
print("c和d的地址相等")
想想最后打印的是什么?
什么是深拷貝和淺拷貝
深拷貝,就是在對(duì)某個(gè)對(duì)象進(jìn)行拷貝的時(shí)候,如果這個(gè)對(duì)象持有其他對(duì)象的引用,在拷貝的時(shí)候會(huì)將要拷貝的對(duì)象以及引用的對(duì)象,一起拷貝。
而淺拷貝只拷貝當(dāng)前對(duì)象和持有的索引,不拷貝索引指向的對(duì)象。舉個(gè)例子說(shuō)明一下,比如當(dāng)前有個(gè)列表a = [1,2,3], b = [3,4,a],[3,4,a]對(duì)象持有了[1,2,3]對(duì)象的引用,在對(duì)b進(jìn)行深拷貝的時(shí)候,會(huì)將a對(duì)象一起拷貝一份,而淺拷貝的時(shí)候則不會(huì)。
a = [1,2,3]
b = [4,5,6,a]
對(duì)b進(jìn)行淺拷貝
c = copy.copy(b)
這個(gè)時(shí)候?qū)對(duì)象進(jìn)行修改,會(huì)影響c
a.append(8)
c
[4, 5, 6, [1, 2, 3, 8]]
對(duì)b進(jìn)行深拷貝之后,再對(duì)a進(jìn)行修改,則不會(huì)影響到d
d = copy.deepcopy(b)
d
[4, 5, 6, [1, 2, 3, 8]]
a.append(66)
d
[4, 5, 6, [1, 2, 3, 8]
當(dāng)深淺拷貝遇到可變與不可變對(duì)象時(shí)會(huì)發(fā)生什么
上面用列表這種可變數(shù)據(jù)結(jié)構(gòu)舉例,再來(lái)看一下元組這種不可變結(jié)構(gòu),在進(jìn)行深淺拷貝時(shí)定的現(xiàn)象。
a = (1,2,3)
b = copy.copy(a)
c = copy.deepcopy(a)
print(id(a))
print(id(b))
print(id(c))
輸出:
4502776896
4502776896
4502776896
從結(jié)果中發(fā)現(xiàn),a、b、c的內(nèi)存地址大都是一樣,所以在對(duì)不可變對(duì)象進(jìn)行拷貝的時(shí)候,無(wú)論是淺拷貝還是深拷貝,都沒(méi)有重新在內(nèi)存中開(kāi)辟新的地址,都只是對(duì)原對(duì)象增加了一個(gè)引用。
那如果不可變對(duì)象匯總包含有對(duì)可變對(duì)象的引用又會(huì)是怎么樣呢?
a1 = [1,2,3]
a = (1,2,3, a1)
b = copy.copy(a)
c = copy.deepcopy(a)
print(id(a))
print(id(b))
print(id(c))
輸出:
4502730288
4502730288
4503232240
b是淺拷貝生成的對(duì)象和原對(duì)象a的內(nèi)存地址是一樣對(duì)的,c是深拷貝生成的對(duì)象,發(fā)現(xiàn)內(nèi)存地址和原對(duì)象a的地址是不一樣的。
也就是說(shuō)如果不可變對(duì)象中持有了可變對(duì)象的引用,在進(jìn)行深拷貝的時(shí)候會(huì)在內(nèi)存中開(kāi)辟新的地址存放對(duì)象。
回到文章開(kāi)頭提出的問(wèn)題,是對(duì)不可變對(duì)象進(jìn)行拷貝,而且不可變對(duì)象中并沒(méi)有持有可變對(duì)象的引用,所以兩個(gè)print語(yǔ)句都會(huì)執(zhí)行。
總結(jié)
以上是生活随笔為你收集整理的测试开发python面试_python测试开发面试之深浅拷贝的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: iOS 数据持久化-- FMDB
- 下一篇: wingdows安装psutil_pyt