go的垃圾回收機(jī)制(GC)

常用的垃圾回收算法
1.引用計(jì)數(shù)(reference counting):如Python
2.標(biāo)記-清掃(mark & sweep):如golang
3.復(fù)制收集(copy and collection):目前許多商業(yè)虛擬機(jī)都采用這種垃圾回收算法

Golang 的三色標(biāo)記法
golang 的垃圾回收(GC)是基于標(biāo)記清掃算法蹲诀,這種算法需要進(jìn)行 STW(stop the world),這個(gè)過程就會(huì)導(dǎo)致程序是卡頓的博个,頻繁的 GC 會(huì)嚴(yán)重影響程序性能. golang 在此基礎(chǔ)上進(jìn)行了改進(jìn)讹蘑,通過三色標(biāo)記清掃法與寫屏障來減少 STW 的時(shí)間.
三色標(biāo)記法的流程如下末盔,它將對(duì)象通過白、灰座慰、黑進(jìn)行標(biāo)記
1.所有對(duì)象最開始都是白色.
2.從 root 開始找到所有可達(dá)對(duì)象陨舱,標(biāo)記為灰色,放入待處理隊(duì)列版仔。
3.歷灰色對(duì)象隊(duì)列游盲,將其引用對(duì)象標(biāo)記為灰色放入待處理隊(duì)列,自身標(biāo)記為黑色邦尊。
4.循環(huán)步驟3直到灰色隊(duì)列為空為止背桐,此時(shí)所有引用對(duì)象都被標(biāo)記為黑色,所有不可達(dá)的對(duì)象依然為白色蝉揍,白色的就是需要進(jìn)行回收的對(duì)象链峭。
三色標(biāo)記法相對(duì)于普通標(biāo)記清掃,減少了 STW 時(shí)間. 這主要得益于標(biāo)記過程是 “on-the-fly” 的又沾,在標(biāo)記過程中是不需要 STW 的弊仪,它與程序是并發(fā)執(zhí)行的,這就大大縮短了 STW 的時(shí)間.

寫屏障
當(dāng)標(biāo)記和程序是并發(fā)執(zhí)行的杖刷,這就會(huì)造成一個(gè)問題. 在標(biāo)記過程中励饵,有新的引用產(chǎn)生,可能會(huì)導(dǎo)致誤清掃. 清掃開始前滑燃,標(biāo)記為黑色的對(duì)象引用了一個(gè)新申請(qǐng)的對(duì)象役听,它肯定是白色的,而黑色對(duì)象不會(huì)被再次掃描表窘,那么這個(gè)白色對(duì)象無法被掃描變成灰色典予、黑色,它就會(huì)最終被清掃乐严,而實(shí)際它不應(yīng)該被清掃. 這就需要用到屏障技術(shù)瘤袖,golang 采用了寫屏障,作用就是為了避免這類誤清掃問題. 寫屏障即在內(nèi)存寫操作前昂验,維護(hù)一個(gè)約束捂敌,從而確保清掃開始前艾扮,黑色的對(duì)象不能引用白色對(duì)象.

GC 觸發(fā)條件
1> 當(dāng)前內(nèi)存分配達(dá)到一定比例則觸發(fā)
2> 2 分鐘沒有觸發(fā)過 GC 則觸發(fā) GC
3> 手動(dòng)觸發(fā),調(diào)用 runtime.GC()

參考文章:https://zhuanlan.zhihu.com/p/111370792?utm_source=wechat_session
————————————————
版權(quán)聲明:本文為CSDN博主「不能吃的堅(jiān)果」的原創(chuàng)文章占婉,遵循CC 4.0 BY-SA版權(quán)協(xié)議泡嘴,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/C_jian/article/details/115165222

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末锐涯,一起剝皮案震驚了整個(gè)濱河市磕诊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌纹腌,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件滞磺,死亡現(xiàn)場(chǎng)離奇詭異升薯,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)击困,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門涎劈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人阅茶,你說我怎么就攤上這事蛛枚。” “怎么了脸哀?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵蹦浦,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我撞蜂,道長(zhǎng)盲镶,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任蝌诡,我火速辦了婚禮溉贿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘浦旱。我一直安慰自己宇色,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布颁湖。 她就那樣靜靜地躺著宣蠕,像睡著了一般。 火紅的嫁衣襯著肌膚如雪爷狈。 梳的紋絲不亂的頭發(fā)上植影,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死惭蹂,一個(gè)胖子當(dāng)著我的面吹牛肛循,可吹牛的內(nèi)容都是我干的咧栗。 我是一名探鬼主播娃胆,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼专挪,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼冠骄!你這毒婦竟也來了博投?” 一聲冷哼從身側(cè)響起绸贡,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎毅哗,沒想到半個(gè)月后听怕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡虑绵,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年尿瞭,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片翅睛。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡声搁,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出捕发,到底是詐尸還是另有隱情疏旨,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布扎酷,位于F島的核電站檐涝,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏霞玄。R本人自食惡果不足惜骤铃,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望坷剧。 院中可真熱鬧惰爬,春花似錦、人聲如沸惫企。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽狞尔。三九已至丛版,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間偏序,已是汗流浹背页畦。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留研儒,地道東北人豫缨。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓独令,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親好芭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子燃箭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容