国产乱子伦高清露脸对白-国产精品欧美久久久久天天影视-国产91视频一区-亚洲欧美日产综合在线网-黄视频网站在线看-国产欧美亚洲精品第1页-亚洲www在线-大学生女人三级在线播放-日本在线视频www鲁啊鲁-国产成人精品一区二区仙踪林-69精品欧美一区二区三区-成人欧美亚洲-日本污污网站-中国妞xxxhd露脸偷拍视频-国产精品aⅴ在线观看-精品中文字幕在线

極客小將

您現在的位置是:首頁 » python編程資訊

資訊內容

剖析Python垃圾回收機制

極客小將2020-12-14-
簡介python教程欄目今天來剖析Python垃圾回收機制!1、垃圾回收引用計數器為主、分代碼回收和標記清除為輔1.1大管家refchain在Python的C源碼中有一個名為refchain的環狀雙向鏈表,這個鏈表比較牛逼了,因為Python程序中一旦創建對象都會把這個對象添加到refchain這個鏈表
python教程欄目今天來剖析Python垃圾回收機制!

PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

1、垃圾回收

引用計數器為主、分代碼回收和標記清除為輔PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

1.1 大管家refchain

在Python的C源碼中有一個名為refchain的環狀雙向鏈表,這個鏈表比較牛逼了,因為Python程序中一旦創建對象都會把這個對象添加到refchain這個鏈表中。也就是說他保存著所有的對象。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

1.2 引用計數器在refchain中的所有對象內部都有一個ob_refcnt用來保存當前對象的引用計數器,顧名思義就是自己被引用的次數。當值被多次引用時候,不會在內存中重復創建數據,而是引用計數器+1 。 當對象被銷毀時候同時會讓引用計數器-1,如果引用計數器為0,則將對象從refchain鏈表中摘除,同時在內存中進行銷毀(暫不考慮緩存等特殊情況)。age = 18number = age # 對象18的引用計數器 + 1del age # 對象18的引用計數器 - 1def run(arg): print(arg) run(number) # 剛開始執行函數時,對象18引用計數器 + 1,當函數執行完畢之后,對象18引用計數器 - 1 。num_list = [11,22,number] # 對象18的引用計數器 + 1復制代碼1.3 標記清除&分代回收

基于引用計數器進行垃圾回收非常方便和簡單,但他還是存在循環引用的問題,導致無法正常的回收一些數據,例如:PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

v1 = [11,22,33] # refchain中創建一個列表對象,由于v1=對象,所以列表引對象用計數器為1.v2 = [44,55,66] # refchain中再創建一個列表對象,因v2=對象,所以列表對象引用計數器為1.v1.append(v2) # 把v2追加到v1中,則v2對應的[44,55,66]對象的引用計數器加1,**終為2.v2.append(v1) # 把v1追加到v1中,則v1對應的[11,22,33]對象的引用計數器加1,**終為2.del v1 # 引用計數器-1del v2 # 引用計數器-1復制代碼對于上述代碼會發現,執行del操作之后,沒有變量再會去使用那兩個列表對象,但由于循環引用的問題,他們的引用計數器不為0,所以他們的狀態:永遠不會被使用、也不會被銷毀。項目中如果這種代碼太多,就會導致內存一直被消耗,直到內存被耗盡,程序崩潰。為了解決循環引用的問題,引入了標記清除技術,專門針對那些可能存在循環引用的對象進行特殊處理,可能存在循環應用的類型有:列表、元組、字典、集合、自定義類等那些能進行數據嵌套的類型。

標記清除:創建特殊鏈表專門用于保存 列表、元組、字典、集合、自定義類等對象,之后再去檢查這個鏈表中的對象是否存在循環引用,如果存在則讓雙方的引用計數器均 - 1 。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

分代回收:對標記清除中的鏈表進行優化,將那些可能存在循引用的對象拆分到3個鏈表,鏈表稱為:0/1/2三代,每代都可以存儲對象和閾值,當達到閾值時,就會對相應的鏈表中的每個對象做一次掃描,除循環引用各自減1并且銷毀引用計數器為0的對象。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

// 分代的C源碼#define NUM_GENERATIONS 3struct gc_generation generations[NUM_GENERATIONS] = { /* PyGC_Head, threshold, count */ {{(uintptr_t)_GEN_HEAD(0), (uintptr_t)_GEN_HEAD(0)}, 700, 0}, // 0代 {{(uintptr_t)_GEN_HEAD(1), (uintptr_t)_GEN_HEAD(1)}, 10, 0}, // 1代 {{(uintptr_t)_GEN_HEAD(2), (uintptr_t)_GEN_HEAD(2)}, 10, 0}, // 2代};復制代碼

特別注意:0代和1、2代的threshold和count表示的意義不同。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

0代,count表示0代鏈表中對象的數量,threshold表示0代鏈表對象個數閾值,超過則執行一次0代掃描檢查。 1代,count表示0代鏈表掃描的次數,threshold表示0代鏈表掃描的次數閾值,超過則執行一次1代掃描檢查。 2代,count表示1代鏈表掃描的次數,threshold表示1代鏈表掃描的次數閾值,超過則執行一2代掃描檢查。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

1.4 情景模擬

根據C語言底層并結合圖來講解內存管理和垃圾回收的詳細過程。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

第一步:當創建對象age=19時,會將對象添加到refchain鏈表中。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

第二步:當創建對象num_list = [11,22]時,會將列表對象添加到 refchain 和 generations 0代中。 PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

第三步:新創建對象使generations的0代鏈表上的對象數量大于閾值700時,要對鏈表上的對象進行掃描檢查。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

當0代大于閾值后,底層不是直接掃描0代,而是先判斷2、1是否也超過了閾值。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

如果2、1代未達到閾值,則掃描0代,并讓1代的 count + 1 。如果2代已達到閾值,則將2、1、0三個鏈表拼接起來進行全掃描,并將2、1、0代的count重置為0.如果1代已達到閾值,則講1、0兩個鏈表拼接起來進行掃描,并將所有1、0代的count重置為0.

對拼接起來的鏈表在進行掃描時,主要就是剔除循環引用和銷毀垃圾,詳細過程為:PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

掃描鏈表,把每個對象的引用計數器拷貝一份并保存到 gc_refs中,保護原引用計數器。再次掃描鏈表中的每個對象,并檢查是否存在循環引用,如果存在則讓各自的gc_refs減 1 。再次掃描鏈表,將 gc_refs 為 0 的對象移動到unreachable鏈表中;不為0的對象直接升級到下一代鏈表中。處理unreachable鏈表中的對象的 析構函數 和 弱引用,不能被銷毀的對象升級到下一代鏈表,能銷毀的保留在此鏈表。析構函數,指的就是那些定義了__del__方法的對象,需要執行之后再進行銷毀處理。**后將 unreachable 中的每個對象銷毀并在refchain鏈表中移除(不考慮緩存機制)。

至此,垃圾回收的過程結束。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

1.5 緩存機制

從上文大家可以了解到當對象的引用計數器為0時,就會被銷毀并釋放內存。而實際上他不是這么的簡單粗暴,因為反復的創建和銷毀會使程序的執行效率變低。Python中引入了“緩存機制”機制。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

例如:引用計數器為0時,不會真正銷毀對象,而是將他放到一個名為 free_list 的鏈表中,之后會再創建對象時不會在重新開辟內存,而是在free_list中將之前的對象來并重置內部的值來使用。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

float類型,維護的free_list鏈表**多可緩存100個float對象。 v1 = 3.14 # 開辟內存來存儲float對象,并將對象添加到refchain鏈表。 print( id(v1) ) # 內存地址:4436033488 del v1 # 引用計數器-1,如果為0則在rechain鏈表中移除,不銷毀對象,而是將對象添加到float的free_list. v2 = 9.999 # 優先去free_list中獲取對象,并重置為9.999,如果free_list為空才重新開辟內存。 print( id(v2) ) # 內存地址:4436033488 # 注意:引用計數器為0時,會先判斷free_list中緩存個數是否滿了,未滿則將對象緩存,已滿則直接將對象銷毀。復制代碼int類型,不是基于free_list,而是維護一個small_ints鏈表保存常見數據(小數據池),小數據池范圍:-5 <= value < 257。即:重復使用這個范圍的整數時,不會重新開辟內存。 v1 = 38 # 去小數據池small_ints中獲取38整數對象,將對象添加到refchain并讓引用計數器+1。 print( id(v1)) #內存地址:4514343712 v2 = 38 # 去小數據池small_ints中獲取38整數對象,將refchain中的對象的引用計數器+1。 print( id(v2) ) #內存地址:4514343712 # 注意:在解釋器啟動時候-5~256就已經被加入到small_ints鏈表中且引用計數器初始化為1, # 代碼中使用的值時直接去small_ints中拿來用并將引用計數器+1即可。另外,small_ints中的數據引用計數器永遠不會為0 # (初始化時就設置為1了),所以也不會被銷毀。復制代碼str類型,維護unicode_latin1[256]鏈表,內部將所有的ascii字符緩存起來,以后使用時就不再反復創建。 v1 = "A" print( id(v1) ) # 輸出:4517720496 del v1 v2 = "A" print( id(v1) ) # 輸出:4517720496 # 除此之外,Python內部還對字符串做了駐留機制,針對只含有字母、數字、下劃線的字符串(見源碼Objects/codeobject.c),如果 # 內存中已存在則不會重新在創建而是使用原來的地址里(不會像free_list那樣一直在內存存活,只有內存中有才能被重復利用)。 v1 = "asdfg" v2 = "asdfg" print(id(v1) == id(v2)) # 輸出:True復制代碼

list類型,維護的free_list數組**多可緩存80個list對象。PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

v1 = [11,22,33] print( id(v1) ) # 輸出:4517628816del v1 v2 = ["你","好"] print( id(v2) ) # 輸出:4517628816復制代碼 tuple類型,維護一個free_list數組且數組容量20,數組中元素可以是鏈表且每個鏈表**多可以容納2000個元組對象。元組的free_list數組在存儲數據時,是按照元組可以容納的個數為索引找到free_list數組中對應的鏈表,并添加到鏈表中。v1 = (1,2) print( id(v1) )del v1 # 因元組的數量為2,所以會把這個對象緩存到free_list[2]的鏈表中。v2 = ("哈哈哈","Alex") # 不會重新開辟內存,而是去free_list[2]對應的鏈表中拿到一個對象來使用。print( id(v2) )復制代碼dict類型,維護的free_list數組**多可緩存80個dict對象 v1 = {"k1":123} print( id(v1) ) # 輸出:4515998128 del v1 v2 = {"name":"哈哈哈","age":18,"gender":"男"} print( id(v1) ) # 輸出:4515998128復制代碼

C語言源碼底層分析PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

相關免費學習推薦:python教程(視頻)PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

以上就是剖析Python垃圾回收機制的詳細內容,更多請關注少兒編程網其它相關文章!PFa少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

預約試聽課

已有385人預約都是免費的,你也試試吧...

国产乱子伦高清露脸对白-国产精品欧美久久久久天天影视-国产91视频一区-亚洲欧美日产综合在线网-黄视频网站在线看-国产欧美亚洲精品第1页-亚洲www在线-大学生女人三级在线播放-日本在线视频www鲁啊鲁-国产成人精品一区二区仙踪林-69精品欧美一区二区三区-成人欧美亚洲-日本污污网站-中国妞xxxhd露脸偷拍视频-国产精品aⅴ在线观看-精品中文字幕在线

        9久久9毛片又大又硬又粗| 青青在线免费视频| 亚洲va综合va国产va中文| 天堂8在线天堂资源bt| 黄色片免费网址| 天天操天天干天天做| 最新av在线免费观看| 国产又粗又猛大又黄又爽| 欧美爱爱视频免费看| 国产日韩av网站| 大陆极品少妇内射aaaaa| 久久久久久久久久久久久久国产| 国产裸体舞一区二区三区| 国产不卡一区二区视频| 亚洲小说欧美另类激情| 天天久久综合网| 国产中文字幕视频在线观看| 亚洲av综合色区| 奇米777四色影视在线看| 久久9精品区-无套内射无码| 国产精品v日韩精品v在线观看| 国内外成人免费激情视频| 国产免费一区二区三区视频| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 国产精品专区在线| 久久久久久久久久一区二区| 欧美性猛交xxxx乱大交91| 日本网站在线看| 91网站在线观看免费| 孩娇小videos精品| 97av中文字幕| 99色这里只有精品| 欧美丰满熟妇xxxxx| 欧美一级中文字幕| av在线播放亚洲| 国产原创精品在线| 欧洲精品在线播放| 国产精品无码av无码| 色一情一乱一乱一区91| 天天摸天天碰天天添| 欧美爱爱视频网站| 在线观看免费av网址| 在线观看视频黄色| 真人抽搐一进一出视频| av丝袜天堂网| 少妇高潮喷水久久久久久久久久| 无限资源日本好片| 成人小视频在线观看免费| 国产wwwxx| 天天影视综合色| 日本xxxxx18| a在线观看免费视频| 日韩久久久久久久久久久久| 九色91popny| 五月丁香综合缴情六月小说| 久久久久国产一区| 国产无限制自拍| 日本三日本三级少妇三级66| 亚洲精品怡红院| 国产超级av在线| 一区二区传媒有限公司| 国产精品一二三在线观看| 日本黄色的视频| 五月天激情视频在线观看| 美女日批免费视频| 亚洲 欧美 综合 另类 中字| 狠狠干狠狠操视频| 成年人免费大片| 日本免费黄视频| 自慰无码一区二区三区| 毛片在线视频观看| 手机在线视频你懂的| 天天色综合社区| 国产成年人视频网站| 亚欧在线免费观看| 熟女少妇精品一区二区| 成年人视频观看| 日本不卡在线观看视频| www.xxx麻豆| 青草网在线观看| 亚洲色成人www永久在线观看| 经典三级在线视频| 免费cad大片在线观看| 一卡二卡三卡视频| 欧美视频在线免费播放| 日本精品久久久久久久久久| 亚洲国产精品成人天堂| 久青草视频在线播放| 无码粉嫩虎白一线天在线观看| 波多野结衣av一区二区全免费观看 | 亚洲色欲久久久综合网东京热| 欧美性受xxxx黑人猛交88| 一级黄色片播放| 久久成人福利视频| 成年网站在线免费观看| 艹b视频在线观看| 国产内射老熟女aaaa| 国产免费黄色一级片| 国产免费人做人爱午夜视频| 亚洲精品怡红院| 穿情趣内衣被c到高潮视频| 在线观看18视频网站| 国产乱子伦农村叉叉叉| 丰满少妇在线观看| 四虎永久免费网站| 131美女爱做视频| 欧美视频免费播放| 在线能看的av网站| 男的插女的下面视频| 老熟妇仑乱视频一区二区| 九九九九九国产| 黄色影院一级片| 在线免费看v片| 日本一本中文字幕| 五月天婷婷影视| www日韩在线观看| 性一交一乱一伧国产女士spa| 91国产精品视频在线观看| 菠萝蜜视频在线观看入口| 在线视频观看91| 欧洲av无码放荡人妇网站| 免费看污污视频| 久久精品一二三四| 国产区二区三区| 999精品网站| 91九色丨porny丨国产jk| 国产精品igao网网址不卡| 亚洲成人福利在线观看| 日本韩国欧美在线观看| 天天干天天色天天爽| 天天综合网久久| 无码日韩人妻精品久久蜜桃| 成人在线观看你懂的| 久久久久福利视频| 黄色一级片网址| 最新黄色av网站| 懂色av粉嫩av蜜臀av| 免费观看黄色的网站| 国产一区二区在线观看免费视频| 精品久久久久久无码国产| 99视频精品免费| 日本不卡一区在线| 日韩av片免费观看| 亚洲图片 自拍偷拍| 中文字幕一区二区在线观看视频 | 国产免费观看高清视频| 国产精品无码免费专区午夜| 黄色成人在线免费观看| www国产免费| 欧美黑人经典片免费观看| 国产aaa免费视频| 亚洲熟妇国产熟妇肥婆| 国产真人做爰毛片视频直播| 欧美激情 国产精品| 国产午夜伦鲁鲁| 日本一极黄色片| www.污污视频| 日韩视频在线观看视频| 成人黄色大片网站| 黄色片一级视频| 五月婷婷丁香色| 中文字幕乱码免费| 日本精品久久久久久久久久| 少妇高清精品毛片在线视频 | 狠狠97人人婷婷五月| 91视频免费版污| 大桥未久一区二区三区| 欧美日韩福利在线| 99热手机在线| 久久久久久久香蕉| 日韩欧美国产免费| 波多野结衣三级在线| 国产男女无遮挡| 激情六月天婷婷| 少妇黄色一级片| 国产精品久久久久9999爆乳| 国产一级做a爰片久久| 中国黄色录像片| www.com操| 欧美s码亚洲码精品m码| 深夜做爰性大片蜜桃| 国产在线青青草| 免费观看中文字幕| 久久九九国产视频| 欧美日韩激情四射| 色播五月激情五月| 女性女同性aⅴ免费观女性恋| www.国产视频.com| 美女网站免费观看视频| 成年人视频网站免费| 午夜两性免费视频| 欧美韩国日本在线| 日韩一级性生活片| 一级黄色片播放| 超碰91在线播放| 91极品尤物在线播放国产| 成人在线观看a| 97国产在线播放| 日韩xxxx视频| 人人干视频在线|