引用技術(shù)的兩個(gè)問題
一:循環(huán)引用的情況下,引用計(jì)數(shù)就不好使了。
a="x"
b=a
a=b
解決方法:
標(biāo)記清除變量的概念:
變量:是由3個(gè)部分組成,1、變量名 2、賦值符號(hào) 3、變量值
變量都是內(nèi)在內(nèi)存中的,在內(nèi)存中有劃分:
棧:變量名(不存值,只是指向一個(gè)內(nèi)存地址)
堆:變量值 --程序員只操控堆,也就是變量值,無法操控棧區(qū)。
比如:x="10" , x="20" 這就意味著 變量的值換了一個(gè)內(nèi)存地址。
我們都是通過變量名(棧)訪問的變量值(堆)
標(biāo)記的過程:掃描棧區(qū)里所有的內(nèi)容,將所有棧區(qū)的對(duì)像,將直接或間接訪問的對(duì)像標(biāo)記成存活對(duì)像,其余的都為非存活,應(yīng)該被清除。
通過棧區(qū)可到達(dá)的對(duì)像是gc roots對(duì)像
標(biāo)記清除:
二:效率問題(低), 引用計(jì)數(shù)引用一次,值就加1,減少就減一 (分代回收解決)
cpython不是時(shí)刻都在回收,而是隔一段時(shí)間去回收一次,這樣就保證效率,cpython使用了分代回收,
1、老年代: 掃描頻率比較低(可能是隔1小時(shí)掃描一次)
老的數(shù)據(jù)可能還在經(jīng)常用
2、年輕代: 掃描頻率比較高(可能是隔5分鐘掃描一次)
因?yàn)樾碌臄?shù)據(jù)用一次就不用了,可能會(huì)被拋棄,這樣有利于內(nèi)存空間的整理
這樣就提升掃描效率
cpython 解釋器垃圾回收機(jī)制是,如果計(jì)數(shù)引用為零的話會(huì)回收,但這樣的話,循環(huán)引用就無法回收了(計(jì)數(shù)不可能為0,循環(huán)引用會(huì)造成內(nèi)存溢出)。
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比雙臺(tái)子網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式雙臺(tái)子網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋雙臺(tái)子地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴。
本文題目:CPython解釋器引用技術(shù)的兩個(gè)問題
分享URL:http://redsoil1982.com.cn/article28/gjpgcp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、品牌網(wǎng)站設(shè)計(jì)、微信小程序、企業(yè)建站、營(yíng)銷型網(wǎng)站建設(shè)、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)