溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

golang垃圾回收中如何實(shí)現(xiàn)刪除寫屏障

發(fā)布時(shí)間:2021-12-15 10:09:21 來源:億速云 閱讀:389 作者:小新 欄目:云計(jì)算

這篇文章將為大家詳細(xì)講解有關(guān)golang垃圾回收中如何實(shí)現(xiàn)刪除寫屏障,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

首先聲明,golang 沒有直接實(shí)現(xiàn)過刪除寫屏障,golang 的內(nèi)存寫屏障是由插入寫屏障到混合寫屏障過渡的。不過,雖然 golang 從來沒有直接使用刪除寫屏障,但是混合寫屏障卻用到了刪除寫屏障的思路。

刪除寫屏障:也叫做基于其實(shí)快照的解決方案(snapshot-at-the-begining)。顧名思義,就是在開始 gc 之前,必須 STW ,對整個(gè)根做一次起始快照。當(dāng)賦值器(業(yè)務(wù)線程)從灰色或者白色對象中刪除白色指針時(shí)候,寫屏障會捕捉這一行為,將這一行為通知給回收器。這樣,基于起始快照的解決方案保守地將其目標(biāo)對象當(dāng)作存活的對象,這樣就絕對不會有被誤回收的對象,但是有掃描工作量浮動放大的風(fēng)險(xiǎn)。術(shù)語叫做追蹤波面的回退。

刪除寫屏障(基于起始快照的寫屏障)有一個(gè)前提條件,就是起始的時(shí)候,把整個(gè)根部掃描一遍,讓所有的可達(dá)對象全都在灰色保護(hù)下(根黑,下一級在堆上的全灰),之后利用刪除寫屏障捕捉內(nèi)存寫操作,確保弱三色不變式不被破壞,就可以保證垃圾回收的正確性。

偽代碼如下:

atomic Write(src, i, ref)    shade(src[i])    src[i] <- ref
 

復(fù)習(xí)一下一些概念

賦值器的顏色

  • 灰色賦值器:如果某一個(gè)賦值器尚未被回收器掃描過(即賦值器的根還沒有被追蹤到),或者盡管被掃描過,但是還需要重新掃描
    • golang 插入寫屏障的時(shí)期,就是灰色賦值器
  • 黑色賦值器:已經(jīng)被回收器掃描過,不會再對其進(jìn)行掃描

插入寫屏障對應(yīng)的是灰色賦值器,刪除寫屏障對應(yīng)的是黑色賦值器。

三色不變式

  • 強(qiáng)三色:不允許黑色對象指向白色對象
  • 弱三色:允許黑色對象指向白色對象,但必須保證一個(gè)前提,這個(gè)白色對象必須處于灰色對象的保護(hù)下

強(qiáng)三色不變式的框架下:要求黑色賦值器的根只能引用灰色或者黑色對象,不能引用白色對象(因?yàn)楹谏x值器不再被掃描,引用白色)。

弱三色不變式的框架下:允許黑色賦值器的根引用白色對象,但前提是白色對象必須處于灰色保護(hù)下。

獲取賦值器的快照,意味著回收器需要掃描其根并將其置為黑色。我們必須在回收起始階段完成賦值器快照的獲取,并保證其不持有任何白色對象。否則一旦賦值器持有某白色對象的唯一引用并將其寫入黑色對象,然后再拋棄該指針,則會違背弱三色不變式的要求。當(dāng)然,為黑色對象增加寫屏障可以捕捉這一內(nèi)存寫操作,但如此一來,該方案將退化到強(qiáng)三色不變式的框架下。因此,基于其實(shí)快照的解決方案將只允許黑色賦值器的存在。

刪除寫屏障怎么保證弱三色不變式,如下示意圖:

golang垃圾回收中如何實(shí)現(xiàn)刪除寫屏障
 

 

我們看到第三張圖顯示,黑色指向白色沒問題,只要最后 delete 指針的時(shí)候 Z 對象置灰色,那么回收的正確性就可以保證。

關(guān)于“golang垃圾回收中如何實(shí)現(xiàn)刪除寫屏障”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI