欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python 垃圾收集機(jī)制的實例詳解

 更新時間:2017年08月20日 16:27:06   作者:wangyuquan  
這篇文章主要介紹了 python 垃圾收集機(jī)制的實例詳解的相關(guān)資料,希望通過本文能幫助大家理解這部分內(nèi)容,需要的朋友可以參考下

 python 垃圾收集機(jī)制的實例詳解

pythonn垃圾收集方面的內(nèi)容如果要細(xì)講還是挺多的,這里只是做一個大概的概括

Python最主要和絕大多數(shù)時候用的都是引用計數(shù),每一個PyObject定義如下:

#define PyObject_HEAD          \ 
  Py_ssize_t ob_refcnt;        \ 
  struct _typeobject *ob_type; 
typedef struct _object { 
  PyObject_HEAD 
} PyObject; 

每個pyobject都有一個refcnt來記錄他們自己的引用數(shù),一旦引用數(shù)為0,就進(jìn)行回收

引用計數(shù)的優(yōu)點在于實時性,一旦沒有其他對象引用了,就能立馬進(jìn)行回收,看起來十分不錯,但為什么好多語言都沒有采用該方案,因為引用計數(shù)有一個致命的缺點,無法解決循環(huán)引用問題,比如:

a = [] 
b = [] 
a.append(b) 
b.append(a) 

其實并沒有其他變量引用a,b那么他們實際上應(yīng)該被回收掉,但由于相互引用的關(guān)系,他們的引用數(shù)都為1,無法被回收。

在python中,相互引用的問題僅僅存在與容器里面,例如list,dictionary,class,instance。為了解決該問題,python引入了標(biāo)記——清除和分代——回收另外兩種機(jī)制。

事實上,python中的容器并沒有之前講的那么簡單,在pyobject_head之前,還有一個PyGC_head,也就是專門用來處理容器的循環(huán)引用問題的。

typedef union _gc_head { 
  struct { 
    union _gc_head *gc_next; 
    union _gc_head *gc_prev; 
    Py_ssize_t gc_refs; 
  } gc; 
  long double dummy; /* force worst-case alignment */ 
} PyGC_Head; 

所有創(chuàng)建的容器類的對象都會被記錄到可收集對象鏈表中,通過上面的結(jié)構(gòu)我們可以知道其實是構(gòu)建了一個雙向鏈表,這樣我們就可以來跟蹤所有可能產(chǎn)生循環(huán)引用的情況了。而像int,string等簡單的不是容器類型的,只要引用技術(shù)為0,就會被回收。但是如果頻繁的malloc和free會嚴(yán)重影響效率,所以python采用了大量的對象池來提高效率。

標(biāo)記——清除包括了垃圾回收的兩個方面:(1)尋找可以回收的對象(2)回收對象,python中的標(biāo)記會從root object開始,遍歷所有容器類對象,查找出可以通過引用來到達(dá)的一些對象,把他們放到由reachable維護(hù)的鏈表中,對于不能到達(dá)的放到unbreachable維護(hù)的鏈表中,此過程結(jié)束之后,對unreachable里面的元素進(jìn)行回收即可。

那么如何對應(yīng)之前循環(huán)引用的情況呢?python里面會產(chǎn)生一個有效的引用數(shù),存在gc.gc_refs里面,像上面的a,b真實引用數(shù)為1,但有效的引用數(shù)為0(循環(huán)中的引用數(shù)都減1),由于不能直接改pyobjec里面的refcnt,否則會產(chǎn)生一系列問題,我們可以將有效的引用數(shù)記到gc.gc_refs里面,那么a,b 的真實有效引用數(shù)都為0,所以他們可以被回收。

下面是另外一種情況:

a = [] 
b = [] 
c = a 
a.append(b) 
b.append(a) 

這里ab也是循環(huán)引用,但是多了c來引用a,通過計算循環(huán)中的有效引用計數(shù)可得a的引用數(shù)為1,b的引用數(shù)為0,看起來b應(yīng)該被回收,但實際上因為a是不可被回收的,a又引用了b,所以b也會被放入在reachable鏈表中,不被回收,其gc.gc_refs還是會被置1的。

另外一種分代回收,是說內(nèi)存中有的對象會頻繁的malloc和free,有的則比較長久,如果一個對象經(jīng)過多次垃圾收集和清除之后還存在的話,那么我們就可以認(rèn)為,這個對象是長時間有用的,不用去頻繁檢測回收它。python中分為3代,分別是3個鏈表維護(hù),0代最多維護(hù)700個對象,1代10個,2代10個,如果對象超過這個數(shù)了,就會調(diào)用標(biāo)記——清除算法來進(jìn)行回收??梢韵氲?,0代的對象經(jīng)過一段時間后會到1代2代中去,然后對它們的檢測回收會相比于0代的不那么頻繁了

要注意的是,python主要的機(jī)制還是引用技術(shù),標(biāo)記——清除和分代收集只是為了彌補(bǔ)引用計數(shù)的缺點而添加的,也就是說,后兩者基本只在容器類的循環(huán)引用上能發(fā)揮作用

以上就是python 垃圾收集機(jī)制的實例詳解,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • python基于物品協(xié)同過濾算法實現(xiàn)代碼

    python基于物品協(xié)同過濾算法實現(xiàn)代碼

    這篇文章主要為大家詳細(xì)介紹了python基于物品協(xié)同過濾算法實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 解決阿里云郵件發(fā)送不能使用25端口問題

    解決阿里云郵件發(fā)送不能使用25端口問題

    這篇文章主要介紹了解決阿里云郵件發(fā)送不能使用25端口問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 基于Python生成個性二維碼過程詳解

    基于Python生成個性二維碼過程詳解

    這篇文章主要介紹了基于Python生成個性二維碼過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • Python使用sftp實現(xiàn)上傳和下載功能

    Python使用sftp實現(xiàn)上傳和下載功能

    這篇文章主要為大家詳細(xì)介紹了Python使用sftp實現(xiàn)上傳和下載功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • 詳解利用python-highcharts庫繪制交互式可視化圖表

    詳解利用python-highcharts庫繪制交互式可視化圖表

    本文主要和大家分享一個超強(qiáng)交互式可視化繪制工具-python-highcharts。python-highcharts就是使用Python進(jìn)行Highcharts項目繪制,簡單的說就是實現(xiàn)Python和Javascript之間的簡單轉(zhuǎn)換層,感興趣的可以了解一下
    2022-03-03
  • Python random模塊(獲取隨機(jī)數(shù))常用方法和使用例子

    Python random模塊(獲取隨機(jī)數(shù))常用方法和使用例子

    這篇文章主要介紹了Python random模塊(獲取隨機(jī)數(shù))常用方法和使用例子,需要的朋友可以參考下
    2014-05-05
  • python文件處理筆記之文本文件

    python文件處理筆記之文本文件

    相信大家在測試任務(wù)過程中都或多或少遇到自己處理文本文件的情況,這篇文章主要給大家介紹了關(guān)于python文件處理筆記之文本文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-08-08
  • Python基礎(chǔ)練習(xí)之用戶登錄實現(xiàn)代碼分享

    Python基礎(chǔ)練習(xí)之用戶登錄實現(xiàn)代碼分享

    這篇文章主要介紹了Python基礎(chǔ)練習(xí)之用戶登錄實現(xiàn)代碼分享,還是比較不錯的,這里分享給大家,供需要的朋友參考。
    2017-11-11
  • Tensorflow深度學(xué)習(xí)使用CNN分類英文文本

    Tensorflow深度學(xué)習(xí)使用CNN分類英文文本

    這篇文章主要為大家介紹了Tensorflow深度學(xué)習(xí)CNN實現(xiàn)英文文本分類示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-11-11
  • python連接、操作mongodb數(shù)據(jù)庫的方法實例詳解

    python連接、操作mongodb數(shù)據(jù)庫的方法實例詳解

    這篇文章主要介紹了python連接、操作mongodb數(shù)據(jù)庫的方法,結(jié)合實例形式詳細(xì)分析了Python針對MongoDB數(shù)據(jù)庫的連接、查詢、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2019-09-09

最新評論