成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Python語法垃圾回收機制原理解析

瀏覽:104日期:2022-08-01 11:18:22

一 引入

解釋器在執(zhí)行到定義變量的語法時,會申請內存空間來存放變量的值,而內存的容量是有限的,這就涉及到變量值所占用內存空間的回收問題,當一個變量值沒有用了(簡稱垃圾)就應該將其占用的內存給回收掉,那什么樣的變量值是沒有用的呢?由于變量名是訪問到變量值的唯一方式,所以當一個變量值不再關聯(lián)任何變量名時,我們就無法再訪問到該變量值了,該變量值就是沒有用的,就應該被當成一個垃圾回收。

毫無疑問,內存空間的申請與回收是非常耗費精力的事情,而且存在很大的危險性,稍有不慎就有可能引發(fā)內存溢出問題,好在Cpython解釋器提供了自動的垃圾回收機制來幫我們 解決了這件事。

二、什么是垃圾回收機制?

垃圾回收機制(簡稱GC)是Python解釋器自帶一種機,專門用來回收不可用的變量值所占用的內存空間

三、為什么要用垃圾回收機制?

程序運行過程中會申請大量的內存空間,而對于一些無用的內存空間如果不及時清理的話會導致內存使用殆盡(內存溢出),導致程序崩潰,因此管理內存是一件重要且繁雜的事情,而python解釋器自帶的垃圾回收機制把程序員從繁雜的內存管理中解放出來。

四、垃圾回收機制原理分析

Python的GC模塊主要運用了“引用計數(shù)”(reference counting)來跟蹤和回收垃圾。在引用計數(shù)的基礎上,還可以通過“標記-清除”(mark and sweep)解決容對象可能產生的循環(huán)引用的問題,并且通過“分代回收”(generation collection)以空間換取時間的方式來進一步提高垃圾回收的效率。

4.1、什么是引用計數(shù)?

引用計數(shù)就是:變量值被變量名關聯(lián)的次數(shù)

如:age=18

變量值18被關聯(lián)了一個變量名age,稱之為引用計數(shù)為1

Python語法垃圾回收機制原理解析

引用計數(shù)增加:

age=18 (此時,變量值18的引用計數(shù)為1)m=age (把age的內存地址給了m,此時,m,age都關聯(lián)了18,所以變量值18的引用計數(shù)為2)

Python語法垃圾回收機制原理解析

引用計數(shù)減少:

age=10(名字age先與值18解除關聯(lián),再與3建立了關聯(lián),變量值18的引用計數(shù)為1)del m(del的意思是解除變量名x與變量值18的關聯(lián)關系,此時,變量18的引用計數(shù)為0)

Python語法垃圾回收機制原理解析

值18的引用計數(shù)一旦變?yōu)?,其占用的內存地址就應該被解釋器的垃圾回收機制回收

4.2、引用計數(shù)擴展閱讀

變量值被關聯(lián)次數(shù)的增加或減少,都會引發(fā)引用計數(shù)機制的執(zhí)行(增加或減少值的引用計數(shù)),這存在明顯的效率問題。

如果說執(zhí)行效率還僅僅是引用計數(shù)機制的一個軟肋的話,那么很不幸,引用計數(shù)機制還存在著一個致命的弱點,即循環(huán)引用(也稱交叉引用)

# 如下我們定義了兩個列表,簡稱列表1與列表2,變量名l1指向列表1,變量名l2指向列表2>>> l1=[’xxx’] # 列表1被引用一次,列表1的引用計數(shù)變?yōu)?>>> l2=[’yyy’] # 列表2被引用一次,列表2的引用計數(shù)變?yōu)?>>> l1.append(l2) # 把列表2追加到l1中作為第二個元素,列表2的引用計數(shù)變?yōu)?>>> l2.append(l1) # 把列表1追加到l2中作為第二個元素,列表1的引用計數(shù)變?yōu)?# l1與l2之間有相互引用# l1 = [’xxx’的內存地址,列表2的內存地址]# l2 = [’yyy’的內存地址,列表1的內存地址]>>> l1[’xxx’, [’yyy’, [...]]]>>> l2[’yyy’, [’xxx’, [...]]]>>> l1[1][1][

循環(huán)引用會導致:值不再被任何名字關聯(lián),但是值的引用計數(shù)并不會為0,應該被回收但不能被回收,什么意思呢?試想一下,請看如下操作

>>> del l1 # 列表1的引用計數(shù)減1,列表1的引用計數(shù)變?yōu)?>>> del l2 # 列表2的引用計數(shù)減1,列表2的引用計數(shù)變?yōu)?

此時,只剩下列表1與列表2之間的相互引用,兩個列表的引用計數(shù)均不為0,但兩個列表不再被任何其他對象關聯(lián),沒有任何人可以再引用到它們,所以它倆占用內存空間應該被回收,但由于相互引用的存在,每一個對象的引用計數(shù)都不為0,因此這些對象所占用的內存永遠不會被釋放,所以循環(huán)引用是致命的,這與手動進行內存管理所產生的內存泄露毫無區(qū)別。所以Python引入了“標記-清除” 與“分代回收”來分別解決引用計數(shù)的循環(huán)引用與效率低的問題

4.2.1 標記-清除

容器對象(比如:list,set,dict,class,instance)都可以包含對其他對象的引用,所以都可能產生循環(huán)引用。而“標記-清除”計數(shù)就是為了解決循環(huán)引用的問題。

在了解標記清除算法前,我們需要明確一點,關于變量的存儲,內存中有兩塊區(qū)域:堆區(qū)與棧區(qū),在定義變量時,變量名與值內存地址的關聯(lián)關系存放于棧區(qū),變量值存放于堆區(qū),內存管理回收的則是堆區(qū)的內容,詳解如下圖,定義了兩個變量x = 10、y = 20

Python語法垃圾回收機制原理解析

當我們執(zhí)行x=y時,內存中的棧區(qū)與堆區(qū)變化如下

Python語法垃圾回收機制原理解析

標記/清除算法的做法是當應用程序可用的內存空間被耗盡的時,就會停止整個程序,然后進行兩項工作,第一項則是標記,第二項則是清除

#1、標記標記的過程其實就是,遍歷所有的GC Roots對象(棧區(qū)中的所有內容或者線程都可以作為GC Roots對象),然后將所有GC Roots的對象可以直接或間接訪問到的對象標記為存活的對象,其余的均為非存活對象,應該被清除。#2、清除清除的過程將遍歷堆中所有的對象,將沒有標記的對象全部清除掉。

直接引用指的是從棧區(qū)出發(fā)直接引用到的內存地址,間接引用指的是從棧區(qū)出發(fā)引用到堆區(qū)后再進一步引用到的內存地址,以我們之前的兩個列表l1與l2為例畫出如下圖像

Python語法垃圾回收機制原理解析

當我們同時刪除l1與l2時,會清理到棧區(qū)中l(wèi)1與l2的內容

Python語法垃圾回收機制原理解析

這樣在啟用標記清除算法時,發(fā)現(xiàn)棧區(qū)內不再有l(wèi)1與l2(只剩下堆區(qū)內二者的相互引用),于是列表1與列表2都沒有被標記為存活,二者會被清理掉,這樣就解決了循環(huán)引用帶來的內存泄漏問題

4.2.2 分代回收

背景:

基于引用計數(shù)的回收機制,每次回收內存,都需要把所有對象的引用計數(shù)都遍歷一遍,這是非常消耗時間的,于是引入了分代回收來提高回收效率,分代回收采用的是用“空間換時間”的策略。

分代:

分代回收的核心思想是:在歷經多次掃描的情況下,都沒有被回收的變量,gc機制就會認為,該變量是常用變量,gc對其掃描的頻率會降低,具體實現(xiàn)原理如下:

分代指的是根據(jù)存活時間來為變量劃分不同等級(也就是不同的代)新定義的變量,放到新生代這個等級中,假設每隔1分鐘掃描新生代一次,如果發(fā)現(xiàn)變量依然被引用,那么該對象的權重(權重本質就是個整數(shù))加一,當變量的權重大于某個設定得值(假設為3),會將它移動到更高一級的青春代,青春代的gc掃描的頻率低于新生代(掃描時間間隔更長),假設5分鐘掃描青春代一次,這樣每次gc需要掃描的變量的總個數(shù)就變少了,節(jié)省了掃描的總時間,接下來,青春代中的對象,也會以同樣的方式被移動到老年代中。也就是等級(代)越高,被垃圾回收機制掃描的頻率越低

回收:

回收依然是使用引用計數(shù)作為回收的依據(jù)Python語法垃圾回收機制原理解析

雖然分代回收可以起到提升效率的效果,但也存在一定的缺點:

例如一個變量剛剛從新生代移入青春代,該變量的綁定關系就解除了,該變量應該被回收,但青春代的掃描頻率低于新生代,所以該變量的回收就會被延遲。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲国产合集| 91.麻豆视频| 精品国产一区二区三区不卡 | 狠狠色噜噜狠狠狠狠色吗综合| 日韩视频在线观看一区二区| 国产精品一品二品| 欧美日韩免费一区二区三区视频| 日日夜夜精品视频免费| 亚洲一区二区毛片| 一区二区三区精品在线| 亚洲日本视频| 国产精品大尺度| 欧美国产先锋| 国产精品午夜免费| 99综合影院在线| 亚洲精品一区二区精华| 成人av在线观| 久久一夜天堂av一区二区三区| 暴力调教一区二区三区| 精品奇米国产一区二区三区| 国产.欧美.日韩| 欧美一级日韩不卡播放免费| 国产精品一区二区男女羞羞无遮挡| 欧美三级在线看| 国内久久婷婷综合| 3d动漫精品啪啪1区2区免费| 国产一区二区美女| 91精品国产综合久久福利软件| 国产精品亚洲а∨天堂免在线| 欧美精选一区二区| 国产精品一卡二卡| 欧美成人性福生活免费看| fc2成人免费人成在线观看播放| 精品久久人人做人人爱| 91影院在线观看| 亚洲国产电影在线观看| 在线欧美亚洲| 亚洲九九爱视频| 免费亚洲一区二区| 青青草精品视频| 欧美精品v国产精品v日韩精品| 国产精品资源站在线| 精品剧情在线观看| 色综合久久中文字幕综合网| 国产日韩亚洲欧美综合| 红桃视频国产精品| 亚洲一区在线免费观看| 久久久久91| 国产在线一区二区综合免费视频| 欧美一级黄色大片| 99久精品国产| 中文字幕日韩一区| 久久国产主播| 国产高清亚洲一区| 中文字幕免费一区| 午夜亚洲一区| 看片的网站亚洲| 欧美一卡二卡在线| 欧美fxxxxxx另类| 亚洲色图视频免费播放| 香蕉久久久久久久av网站| 奇米综合一区二区三区精品视频| 在线观看91av| 成人网在线播放| 中文字幕中文字幕一区二区| 久久欧美肥婆一二区| 久久精品国产亚洲高清剧情介绍| 91精品国产色综合久久ai换脸| 91视视频在线观看入口直接观看www | 在线影视一区二区三区| 国产剧情一区二区三区| 久久综合九色综合久久久精品综合| 国产精品xnxxcom| 亚洲国产视频一区二区| 欧美日韩国产区一| 国产一区二区三区综合| 精品国产123| 夜久久久久久| 日韩国产欧美一区二区三区| 欧美日本在线视频| 波多野结衣的一区二区三区| 国产精品国产精品国产专区不蜜| 国产欧美一区二区三区另类精品 | 欧美成人有码| 一区二区不卡在线播放 | 亚洲精品视频观看| 欧洲精品一区二区| 成人动漫av在线| 1000精品久久久久久久久| 欧美亚洲视频| 激情六月婷婷久久| 国产午夜精品一区二区三区视频| 亚洲国产精品日韩| 久久精品久久综合| 国产婷婷色一区二区三区在线| 久久精品主播| 风间由美一区二区三区在线观看| 国产精品免费丝袜| 久久久久久国产精品mv| 丁香婷婷深情五月亚洲| ●精品国产综合乱码久久久久| 久久综合伊人| 不卡一区二区在线| 17c精品麻豆一区二区免费| 久久婷婷激情| 成人一级黄色片| 亚洲综合视频在线| 日韩视频在线永久播放| 亚洲毛片网站| 国产在线播放一区| 欧美激情综合五月色丁香| 久久精品系列| 欧美91大片| 天天综合色天天综合| 91精品国产一区二区三区| 亚洲国产合集| 精品亚洲欧美一区| 亚洲天堂2016| 制服丝袜亚洲精品中文字幕| 精品动漫3d一区二区三区免费| 免费成人小视频| 国产精品久久久久久久久图文区 | 精品在线播放午夜| 中文字幕永久在线不卡| 日本高清不卡一区| 欧美网站在线| 成人做爰69片免费看网站| 性感美女极品91精品| 久久精品水蜜桃av综合天堂| 久久国产精品毛片| 99精品欧美一区二区蜜桃免费| 亚洲成人精品一区| 国产亚洲欧美在线| 欧美日韩一区二区三区在线看| 精品1区2区3区4区| 国产精品1区2区3区| 亚洲图片欧美视频| 久久精品人人爽人人爽| 91福利精品第一导航| 欧美搞黄网站| 国内精品久久久久影院一蜜桃| 亚洲成人资源网| 欧美国产日韩精品免费观看| 欧美精品一二三| 免费看的黄色欧美网站| 欧美阿v一级看视频| 国内成人免费视频| 亚洲午夜视频在线| 国产精品视频一二三| 日韩一区二区免费视频| 一本色道综合亚洲| 亚洲午夜精品久久| 北条麻妃国产九九精品视频| 六月丁香婷婷色狠狠久久| 亚洲午夜免费电影| 中文字幕在线不卡一区| 精品国产乱码久久久久久免费| 色呦呦一区二区三区| 精品动漫一区| 欧美在线国产| 丰满岳乱妇一区二区三区| 水野朝阳av一区二区三区| 亚洲欧洲日产国产综合网| 精品伦理精品一区| 欧美乱妇23p| 色婷婷国产精品综合在线观看| 亚洲国产第一| 欧美日韩国产免费观看| 欧美在线网址| 国产 日韩 欧美大片| 久久99精品视频| 五月婷婷色综合| 亚洲欧美日韩一区二区三区在线观看| ww久久中文字幕| 91精品国产91久久久久久最新毛片 | 成人18精品视频| 国产精品夜夜嗨| 久久66热偷产精品| 日韩电影在线一区| 亚洲成人久久影院| 国产精品成人一区二区艾草| 国产精品久久久久久久久久久免费看| 26uuu亚洲综合色欧美| 51午夜精品国产| 欧美三级日韩三级国产三级| 色哟哟一区二区| 久久久久久亚洲精品杨幂换脸 | 国产欧美一区二区三区鸳鸯浴| 亚洲精品在线网站| 欧美成人a∨高清免费观看| 88在线观看91蜜桃国自产| 91精品蜜臀在线一区尤物| 欧美视频一区二区在线观看| 久久午夜精品| 久久久777| 色哟哟日韩精品| 色88888久久久久久影院野外| 久久综合狠狠| 欧美三级午夜理伦三级中视频| 欧美亚洲综合网|