国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

            手機(jī)站
            千鋒教育

            千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

            千鋒教育

            掃一掃進(jìn)入千鋒手機(jī)站

            領(lǐng)取全套視頻
            千鋒教育

            關(guān)注千鋒學(xué)習(xí)站小程序
            隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

            當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Python淺拷貝和深度拷貝

            Python淺拷貝和深度拷貝

            來(lái)源:千鋒教育
            發(fā)布人:xqq
            時(shí)間: 2023-11-07 01:01:31 1699290091

            前面介紹了Python的賦值(對(duì)象的引用傳遞),那么Python如何解決原始數(shù)據(jù)在函數(shù)傳遞后不受影響呢,Python提供了淺度拷貝(shallowcopy)和深度拷貝(deepcopy)兩種方式。

            ·淺拷貝(copy):拷貝父對(duì)象,不拷貝對(duì)象內(nèi)部的子對(duì)象。

            ·深拷貝(deepcopy):完全拷貝了父對(duì)象及其子對(duì)象。

            淺拷貝

            1.不可變數(shù)據(jù)類型

            下面對(duì)不可變對(duì)象整型變量和元組進(jìn)行淺拷貝:

            importcopy

            a=1

            b=copy.copy(a)

            print(id(a))

            print(id(b))

            print(a==b)

            print(aisb)

            t1=(1,2,3)

            t2=tuple(t1)

            print(id(t1))

            print(id(t2))

            print(t1==t2)

            print(t1ist2)

            執(zhí)行結(jié)果:

            50622072

            50622072

            True

            True

            55145384

            55145384

            True

            True

            不可變對(duì)象的拷貝和對(duì)象的引用傳遞一樣,a、b指向相同的對(duì)象,修改其中一個(gè)變量的值不會(huì)影響另外的變量,會(huì)開(kāi)辟新的空間。

            2.可變數(shù)據(jù)類型

            對(duì)可變對(duì)象list進(jìn)行淺拷貝:

            importcopy

            l1=[1,2,3]

            l2=list(l1)

            l3=copy.copy(l1)

            l4=l1[:]

            print(id(l1))

            print(id(l2))

            print(l1==l2)

            print(l1isl2)

            print(id(l3))

            print(id(l4))

            l1.append(4)

            print(id(l1))

            print(l1==l2)

            print(l1isl2)

            執(zhí)行結(jié)果:

            48520904

            48523784

            True

            False

            48523848

            48521032

            48520904

            False

            False

            可以看到,對(duì)可變對(duì)象的淺拷貝會(huì)重新分配一塊內(nèi)存,創(chuàng)建一個(gè)新的對(duì)象,里面的元素是原對(duì)象中子對(duì)象的引用。改變l1的值不會(huì)影響l2,l3,l4的值,它們指向不同的對(duì)象。

            上面的例子比較簡(jiǎn)單,下面舉一個(gè)相對(duì)復(fù)雜的數(shù)據(jù)結(jié)構(gòu):

            importcopy

            l1=[[1,2],(4,5)]

            l2=copy.copy(l1)

            print(id(l1))

            print(id(l2))

            print(id(l1[0]))

            print(id(l2[0]))

            l1.append(6)

            print(l1)

            print(l2)

            l1[0].append(3)

            print(l1)

            print(l2)

            執(zhí)行結(jié)果:

            1918057951816

            1918057949448

            2680328991496

            2680328991496

            [[1,2],(4,5),6]

            [[1,2],(4,5)]

            [[1,2,3],(4,5),6]

            [[1,2,3],(4,5)]

            l2是l1的淺拷貝,它們指向不同的對(duì)象,因?yàn)闇\拷貝里的元素是對(duì)原對(duì)象元素的引用,因此l2中的元素和l1指向同一個(gè)列表和元組對(duì)象(l1[0]和l2[0]指向的是相同的地址)。l1.append(6)不會(huì)對(duì)l2產(chǎn)生任何影響,因?yàn)閘2和l1作為整體是兩個(gè)不同的對(duì)象,不共享內(nèi)存地址。

            l1[0].append(3)對(duì)l1中的第一個(gè)列表新增元素3,因?yàn)閘2是l1的淺拷貝,l2中的第一個(gè)元素和l1中的第一個(gè)元素,共同指向同一個(gè)列表,因此l2中的第一個(gè)列表也會(huì)相對(duì)應(yīng)的新增元素3。

            這里提一個(gè)小問(wèn)題:如果對(duì)l1中的元組新增元素(l1[1]+=(7,8)),會(huì)影響l2嗎?

            到這里我們知道使用淺拷貝可能帶來(lái)的副作用,要避免它就得使用深度拷貝。

            深度拷貝

            深度拷貝會(huì)完整地拷貝一個(gè)對(duì)象,會(huì)重新分配一塊內(nèi)存,創(chuàng)建一個(gè)新的對(duì)象,并且將原對(duì)象中的元素以遞歸的方式,通過(guò)創(chuàng)建新的子對(duì)象拷貝到新對(duì)象中。因此,新對(duì)象和原對(duì)象沒(méi)有任何關(guān)聯(lián),也就是完全拷貝了父對(duì)象及其子對(duì)象。

            importcopy

            l1=[[1,2],(4,5)]

            l2=copy.deepcopy(l1)

            print(id(l1))

            print(id(l2))

            l1.append(6)

            print(l1)

            print(l2)

            l1[0].append(3)

            print(l1)

            print(l2)

            執(zhí)行結(jié)果:

            3026088342280

            3026088342472

            [[1,2],(4,5),6]

            [[1,2],(4,5)]

            [[1,2,3],(4,5),6]

            [[1,2],(4,5)]

            可以看到,l1變化不影響l2,l1和l2完全獨(dú)立,沒(méi)有任何聯(lián)系。

            在進(jìn)行深度拷貝時(shí),深度拷貝deepcopy中會(huì)維護(hù)一個(gè)字典,記錄已經(jīng)拷貝的對(duì)象與其ID。如果字典里已經(jīng)存儲(chǔ)了將要拷貝的對(duì)象,則會(huì)從字典直接返回。

            以上內(nèi)容為大家介紹了Python淺拷貝和深度拷貝,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://www.parentadvocate.org/

            聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
            10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
            請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
            免費(fèi)領(lǐng)取
            今日已有369人領(lǐng)取成功
            劉同學(xué) 138****2860 剛剛成功領(lǐng)取
            王同學(xué) 131****2015 剛剛成功領(lǐng)取
            張同學(xué) 133****4652 剛剛成功領(lǐng)取
            李同學(xué) 135****8607 剛剛成功領(lǐng)取
            楊同學(xué) 132****5667 剛剛成功領(lǐng)取
            岳同學(xué) 134****6652 剛剛成功領(lǐng)取
            梁同學(xué) 157****2950 剛剛成功領(lǐng)取
            劉同學(xué) 189****1015 剛剛成功領(lǐng)取
            張同學(xué) 155****4678 剛剛成功領(lǐng)取
            鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
            董同學(xué) 138****2867 剛剛成功領(lǐng)取
            周同學(xué) 136****3602 剛剛成功領(lǐng)取
            相關(guān)推薦HOT
            Python處理文件的幾個(gè)常用小知識(shí)

            python這門語(yǔ)言有個(gè)很大的用途就是使用它來(lái)進(jìn)行文件處理,學(xué)會(huì)處理文件和保存數(shù)據(jù)可以讓你的程序使用起來(lái)更加容易和方便,因此小編為大家準(zhǔn)備了...詳情>>

            2023-11-07 03:54:20
            python經(jīng)典最短代碼實(shí)現(xiàn)排序的功能

            冒泡排序:算法思想:1.比較相鄰的元素,如果第一個(gè)比第二個(gè)大,則交換他們的位置;2.依次對(duì)每一對(duì)的元素進(jìn)行比較,如果前一個(gè)比后一個(gè)大,則交...詳情>>

            2023-11-07 03:50:44
            Python五大應(yīng)用領(lǐng)域

            1、Linux運(yùn)維用python實(shí)現(xiàn)的測(cè)試工具及過(guò)程,包含服務(wù)器端、客戶端、web、andriod、client端的自動(dòng)化測(cè)試,自動(dòng)化性能測(cè)試的執(zhí)行、監(jiān)控和分析,...詳情>>

            2023-11-07 03:25:32
            Python與Node.JS

            在進(jìn)行新項(xiàng)目時(shí)選擇正確的編程語(yǔ)言可能是程序員經(jīng)常做出的比較艱巨的決定之一。這個(gè)挑戰(zhàn)背后的原因是,每個(gè)新項(xiàng)目都會(huì)遇到一個(gè)獨(dú)特的問(wèn)題,并且...詳情>>

            2023-11-07 03:14:44
            如何殺死一個(gè)Python線程

            我經(jīng)常被問(wèn)到如何殺死一個(gè)后臺(tái)線程,這個(gè)問(wèn)題的答案讓很多人不開(kāi)心:線程是殺不死的。在本文中,我將向您展示Python中用于終止線程的兩個(gè)選項(xiàng)。...詳情>>

            2023-11-07 02:56:44