日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

python內(nèi)存管理機(jī)制原理詳解

系統(tǒng) 1953 0

python內(nèi)存管理機(jī)制:

  • 引用計(jì)數(shù)
  • 垃圾回收
  • 內(nèi)存池

1. 引用計(jì)數(shù)

當(dāng)一個(gè)python對(duì)象被引用時(shí) 其引用計(jì)數(shù)增加 1 ; 當(dāng)其不再被變量引用時(shí) 引用計(jì)數(shù)減 1 ; 當(dāng)對(duì)象引用計(jì)數(shù)等于 0 時(shí), 對(duì)象被刪除(引用計(jì)數(shù)是一種非常高效的內(nèi)存管理機(jī)制)

2. 垃圾回收

垃圾回收機(jī)制: ① 引用計(jì)數(shù) , ②標(biāo)記清除 , ③分帶回收

引用計(jì)數(shù) :

引用計(jì)數(shù)也是一種垃圾收集機(jī)制, 而且也是一種最直觀, 最簡(jiǎn)單的垃圾收集技術(shù).當(dāng)python某個(gè)對(duì)象的引用計(jì)數(shù)降為 0 時(shí), 說(shuō)明沒(méi)有任何引用指向該對(duì)象, 該對(duì)象就成為要被回收的垃圾了.(如果出現(xiàn)循環(huán)引用的話, 引用計(jì)數(shù)機(jī)制就不再起作用了)

標(biāo)記清除 :

如果兩個(gè)對(duì)象的引用計(jì)數(shù)都為 1 , 但是僅僅存在他們之間的循環(huán)引用,那么這兩個(gè)對(duì)象都是需要被回收的, 也就是說(shuō) 它們的引用計(jì)數(shù)雖然表現(xiàn)為非 0 , 但實(shí)際上有效的引用計(jì)數(shù)為 0 ,.所以先將循環(huán)引用摘掉, 就會(huì)得出這兩個(gè)對(duì)象的有效計(jì)數(shù).

分帶回收 :

從前面“標(biāo)記-清除”這樣的垃圾收集機(jī)制來(lái)看,這種垃圾收集機(jī)制所帶來(lái)的額外操作實(shí)際上與系統(tǒng)中總的內(nèi)存塊的數(shù)量是相關(guān)的,當(dāng)需要回收的內(nèi)存塊越多時(shí),垃圾檢測(cè)帶來(lái)的額外操作就越多,而垃圾回收帶來(lái)的額外操作就越少;反之,當(dāng)需要回收的內(nèi)存塊越少時(shí),垃圾檢測(cè)就將比垃圾回收帶來(lái)更少的額外操作。

3.內(nèi)存池

內(nèi)存池機(jī)制: python 中分為大內(nèi)存和小內(nèi)存: 256k為界限

大內(nèi)存使用malloc 進(jìn)行分配

小內(nèi)存使用內(nèi)存池是進(jìn)行分配

python的內(nèi)存池金字塔:

第3層: 最上層, 用戶對(duì)python對(duì)象的直接操作

第1層和第2層: 內(nèi)存池, 有python 的 接口函數(shù) PyMen_Malloc 實(shí)現(xiàn), 若請(qǐng)求分配的內(nèi)存在1 - 256字節(jié)之間就使用內(nèi)存池進(jìn)行分配, 調(diào)用malloc 函數(shù)分配內(nèi)存, 但是每次只會(huì)分配 256 k 的內(nèi)存. 不會(huì)調(diào)用free 函數(shù)釋放內(nèi)層. 將該內(nèi)存塊留在內(nèi)存池中便下次使用

第 0 層: 大內(nèi)存 . 若請(qǐng)求分配的內(nèi)存大于 256 k , malloc函數(shù)分配, free函數(shù)釋放內(nèi)存

第 - 1 -2 層: 操作系統(tǒng)進(jìn)行操作

python內(nèi)存管理機(jī)制原理詳解_第1張圖片

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 沛县| 叙永县| 太仆寺旗| 改则县| 普洱| 确山县| 井研县| 柘城县| 双桥区| 新安县| 遂平县| 湟源县| 德化县| 温宿县| 改则县| 申扎县| 格尔木市| 政和县| 武乡县| 磐安县| 永吉县| 成都市| 柳州市| 沁源县| 陆丰市| 邵东县| 乐亭县| 花垣县| 浮山县| 芜湖市| 故城县| 安阳市| 上思县| 措美县| 微博| 同心县| 甘洛县| 毕节市| 汉源县| 宿州市| 龙江县|