国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

JVM 三色標記算法,原來是這么回事!

開發 前端
三色標記算法是什么? 三色標記算法是根可達算法的一種實現方案,其目的是為了找出所有可達對象。

最近和一個朋友聊天,他問了我 JVM 的三色標記算法。我腦袋一愣發現竟然完全不知道!于是我帶著疑問去網上看了幾天的資料,終于搞清楚啥事三色標記算法,它是用來干嘛的,以及它和 CMS 回收器和 G1 回收器的關系了。今天,就讓樹哥帶著大家一起盤一盤它!

圖片

文章思維導圖

根可達算法

我們要進行垃圾回收,就需要弄明白哪些對象是需要回收的,哪些對象是不需要回收的。針對這個問題,其實業界已經有幾種常見的解決方法了。

第一種是計數法,就是每個對象都有一個計數器,被引用了加一,移除引用減一。但這種方法比較麻煩,而且也會有循環依賴的問題,因此并不被廣泛使用。第二種是根可達算法,即以 GCRoots 為基礎去掃描整個引用鏈,從而找到所有的可達對象,那剩下的其他對象就是不可達的垃圾對象了。

現在被廣泛使用的是第二種算法,即根可達算法。

那怎么去實現根可達算法呢?

最簡單的一種實現方案是:從 GCRoots 節點開始,使用「標記 - 清除」算法去實現。

這種實現方案分為兩個階段,分別是:標記階段、清除階段。在標記階段,它從 GCRoots 節點開始掃描整個引用鏈,找到所有可達的對象。在清除階段,掃描整個引用鏈的不可達對象,然后將垃圾對象清除掉。整個算法實現過程如下圖所示。

圖片

圖片引用自維基百科

但這種方式有一個很大的缺點:整個過程必須「Stop the World」。這就導致整個應用程序必須停止,不能做任何改變,這是非常不友好的。 CMS 回收器出現之前的所有回收器,都是用這種方式實現的,因此 GC 停頓時間都比轎長。

三色標記算法

為了解決上面「標記 - 清除」算法的問題,于是就出現了「三色標記算法」!

三色標記算法指的是將所有對象分為白色、黑色和灰色三種類型。黑色表示從 GCRoots 開始,已掃描過它全部引用的對象,灰色指的是掃描過對象本身,還沒完全掃描過它全部引用的對象,白色指的是還沒掃描過的對象。

圖片

圖片引用自維基百科

但僅僅將對象劃分成三個顏色還不夠,真正關鍵的是:實現根可達算法的時候,將整個過程拆分成了初始標記、并發標記、重新標記、并發清除四個階段。

  • 初始標記階段,指的是標記 GCRoots 直接引用的節點,將它們標記為灰色,這個階段需要 「Stop the World」。
  • 并發標記階段,指的是從灰色節點開始,去掃描整個引用鏈,然后將它們標記為黑色,這個階段不需要「Stop the World」。
  • 重新標記階段,指的是去校正并發標記階段的錯誤,這個階段需要「Stop the World」。
  • 并發清除,指的是將已經確定為垃圾的對象清除掉,這個階段不需要「Stop the World」。

對比一下「四階段拆分」和「一段式」的實現方式,我們可以看出:通過將最耗時的引用鏈掃描剝離出來作為并發標記階段,將其與用戶線程并發執行,從而極大地降低了 GC 停頓時間。 但 GC 線程與用戶線程并發執行,會帶來新的問題:對象引用關系可能會發生變化,有可能發生多標和漏標問題。

多標與漏標問題

多標問題指的是原本應該回收的對象,被多余地標記為黑色存活對象,從而導致該垃圾對象沒有被回收。 多標問題會出現,是因為在并發標記階段,有可能之前已經被標記為存活的對象,其引用被刪除,從而變成了不可達對象。例如下圖中,假設我們現在遍歷到了節點 E,此時應用執行了 objD.fieldE = null;。那么此刻之后,對象 E、F、G 應該是被回收的。但因為節點 E 已經是灰色的,那么 E、F、G 節點都會被標記為存活的黑色狀態,并不會被回收。

圖片

圖片來自網絡

多標問題會導致內存產生浮動垃圾,但好在其可以再下次 GC 的時候被回收,因此問題還不算很嚴重。

漏標問題指的是原本應該被標記為存活的對象,被遺漏標記為黑色,從而導致該垃圾對象被錯誤回收。 例如下圖中,假設我們現在遍歷到了節點 E,此時應用執行如下代碼。這時候因為 E 對象沒有引用了 G 對象,因此掃描 E 對象的時候并不會將 G 對象標記為黑色存活狀態。但由于用戶線程的 D 對象引用了 G 對象,這時候 G 對象應該是存活的,應該標記為黑色。但由于 D 對象已經被掃描過了,不會再次掃描,因此 G 對象就被漏標了。

var G = objE.fieldG; 
objE.fieldG = null; // 灰色E 斷開引用 白色G
objD.fieldG = G; // 黑色D 引用 白色G

圖片

圖片來自網絡

漏標問題就非常嚴重了,其會導致存活對象被回收,會嚴重影響程序功能。

那么我們的垃圾回收器是怎么解決這個問題的呢?

答案是:增加一個「重新標記」階段。無論是在 CMS 回收器還是 G1 回收器,它們都在并發標記階段之后,新增了一個「重新標記」階段來校正「并發標記」階段出現的問題。 只是對于 CMS 回收器和 G1 回收器來說,它們解決的原理不同罷了。

漏標解決方案

正如前面所說,三色標記算法會造成漏標和多標問題。但多標問題相對不是那么嚴重,而漏標問題才是最嚴重的。我們經過分析可以知道,漏標問題要發生需要滿足如下兩個充要條件:

  • 有至少一個黑色對象在自己被標記之后指向了這個白色對象
  • 所有的灰色對象在自己引用掃描完成之前刪除了對白色對象的引用

只有當上面兩個條件都滿足,三色標記算法才會發生漏標的問題。換言之,如果我們破壞任何一個條件,這個白色對象就不會被漏標。這其實就產生了兩種方式,分別是:增量更新、原始快照。CMS 回收器使用的增量更新方案,G1 采用的是原始快照方案。

CMS 解決方案

CMS 回收器采用的是增量更新方案,即破壞第一個條件:「有至少一個黑色對象在自己被標記之后指向了這個白色對象」。

既然有黑色對象在自己標記后,又重新指向了白色對象。那么我就把這個黑色對象的引用記錄下來,在后續「重新標記」階段再以這個黑色對象為跟,對其引用進行重新掃描。通過這種方式,被黑色對象引用的白色對象就會變成灰色,從而變為存活狀態。

這種方式有個缺點,就是會重新掃描新增的這部分黑色對象,會浪費多一些時間。但是這段時間相對于并發標記整個鏈路的掃描,還是小巫見大巫,畢竟真正發生引用變化的黑色對象是比較少的。

G1 解決方案

G1 回收器采用的是原始快照的方案,即破壞第二個條件:「所有的灰色對象在自己引用掃描完成之前刪除了對白色對象的引用」。

既然灰色對象在掃描完成后刪除了對白色對象的引用,那么我是否能在灰色對象取消引用之前,先將灰色對象引用的白色對象記錄下來。隨后在「重新標記」階段再以白色對象為根,對它的引用進行掃描,從而避免了漏標的問題。通過這種方式,原本漏標的對象就會被重新掃描變成灰色,從而變為存活狀態。

這種方式有個缺點,就是會產生浮動垃圾。 因為當用戶線程取消引用的時候,有可能是真的取消引用,對應的對象是真的要回收掉的。這時候我們通過這種方式,就會把本該回收的對象又復活了,從而導致出現浮動垃圾。但相對于本該存活的對象被回收,這個代碼還是可以接受的,畢竟在下次 GC 的時候就可以回收了。

對于 CMS 和 G1 這兩種處理方案哪種更好,很多資料說的是 G1 這種解決方案更好。 原因是其覺得 G1 這種方式產生了一些浮動垃圾,但節省了一些時間。但我對比了一下發現:CMS 和 G1 都需要重新對某些元素進行引用鏈掃描。從這點看來,好像差別不大。有弄懂的朋友可以評論區留言討論討論。

總結

看完了整篇文章,我們試圖來回答一些問題。

三色標記算法是什么? 三色標記算法是根可達算法的一種實現方案,其目的是為了找出所有可達對象。

為什么要有三色標記算法? 因為傳統的「標記 - 清除」算法效率太低,于是采用三色標記算法通過將對象分成白色、黑色、灰色,以及將整個過程拆分成「初始標記、并發標記、重新標記、并發清除」4 個過程,從而降低 GC 停頓時間。

三色標記算法有什么缺陷? 三色標記算法會產生多標和漏標問題,其中漏標問題最嚴重。漏標問題會導致本該存活的對象被回收,從而導致嚴重的程序問題。

漏標有什么解決方案? 漏標有兩種解決方案,分別是:增量更新和原始快照方式。CMS 回收器采用了增量更新方式,G1 回收器采用了原始快照方式。

漏標哪種解決方案最好? 江湖傳聞 G1 回收器的原始快照方式效率高,但沒有確切的理論證明,且聽且珍惜。

參考資料

  • 非常好!權威資料!VIP!!Tracing garbage collection - Wikipedia
  • VIP!VIP!講清楚了!三色標記的漏標問題及兩種解決方案_小幻_159 的博客 - CSDN 博客_三色標記漏標
  • 三色標記法:多標與漏標 - 愛代碼愛編程
  • 三色標記!!!12. 垃圾收集底層算法 -- 三色標記詳解 - 騰訊云開發者社區 - 騰訊云
  • 三色標記!!!GC 中的 三色標記法_騷人貴的博客 - CSDN 博客_gc 三色標記
  • 三色標記法:多標與漏標_朱四龍的博客 - CSDN 博客_三色標記漏標
責任編輯:武曉燕 來源: 樹哥聊編程
相關推薦

2020-06-30 08:12:32

VMwareKVMDocker

2025-04-03 10:39:56

2021-07-29 16:56:59

微信騰訊注冊

2023-01-08 13:46:49

2025-07-03 07:05:00

JavaScriptPromise代碼

2025-01-06 08:22:41

2022-10-21 08:17:13

MongoDB查詢Document

2021-08-16 10:35:52

JVM標記法屏障

2018-06-04 08:40:20

磁盤分區MBR

2021-08-06 11:46:46

Go三色標記法

2021-02-07 08:13:18

@DateTimeFo@NumberFormSpring

2023-06-19 07:12:51

JVM三色標記

2020-03-04 08:47:10

Kafka架構原理

2020-02-23 15:55:00

疫情AI人工智能

2020-11-12 07:32:53

JavaScript

2020-07-09 15:45:22

GoGC內存

2020-05-26 08:52:36

Java JVM多態

2022-01-14 14:19:38

ReactTS前端

2024-10-11 11:59:03

2017-06-06 15:13:07

點贊
收藏

51CTO技術棧公眾號

一区二区三区日本久久久| 日韩精品中文字幕久久臀| 日韩中文字幕免费在线| 久久奇米777| 国产国产人免费人成免费视频 | 人人妻人人添人人爽欧美一区| 精品亚洲国产成人av制服丝袜| 日韩视频精品| 99精品在线观看视频| 97涩在线观看视频| 欧美日韩中文字幕一区| 丝袜美腿诱惑一区二区三区| 国内精品久久影院| 亚洲欧洲视频| 欧美黄网站在线观看| 亚洲欧美日韩国产一区二区三区| 色网址在线观看| 亚洲变态欧美另类捆绑| 国产精品亚洲欧美一级在线| 成人国产精品色哟哟| 国产一区久久久| 免费国产视频| 亚洲精品乱码久久久久久金桔影视 | 国产又黄又爽免费视频| 国产精品高清亚洲| 国产黄大片在线观看画质优化| 久久天天躁狠狠躁夜夜躁2014| 国产精品成人a在线观看| 蜜臀av性久久久久蜜臀av| 亚洲在线成人精品| 美女100%一区| 成人福利网站在线观看| 成人午夜视频免费看| 伊人网站在线| 日韩中文理论片| 欧美日韩国产欧| 成人中文字幕在线播放| 欧美性做爰猛烈叫床潮| 日韩精品一区国产| 久久涩涩网站| 亚洲国产精品成人综合| 黄页视频在线播放| 欧洲美女免费图片一区| 狠狠色丁香久久婷婷综合丁香| 淫视频在线观看| 中文字幕国产精品久久| 欧美在线影院| 成人狠狠色综合| 亚洲天堂男人天堂| 欧美一级一区| 中文资源在线网| 欧美麻豆久久久久久中文| 亚洲欧美日韩视频二区| 香港三级经典全部种子下载| 亚洲欧洲日本专区| 一区二区三区精品视频在线观看| 五月婷婷开心综合| 亚洲欧美在线x视频| 日韩午夜在线| 色视频免费在线观看| 992tv在线成人免费观看| 国产a久久麻豆| av成人福利| 久久精品国产第一区二区三区最新章节| 怡红院av一区二区三区| 日韩精品成人| 日韩av在线播放不卡| 精品福利视频一区二区三区| 亚洲精品小说| av女同在线| 97视频在线观看播放| 成人在线综合网| 国产精品迅雷| 色女孩综合网| 777午夜精品免费视频| 午夜激情久久| 久草视频在线播放| 国产成人一区二区三区电影| 国产亚洲视频系列| 欧美黄色成人| 999一区二区三区| 亚洲人成网站777色婷婷| 久久青草久久| 激情av在线| 亚洲无玛一区| 亚洲精品国精品久久99热| 免费中文字幕日韩欧美| 久久新电视剧免费观看| 国产精品久久久久久久| 性欧美精品孕妇| 动漫精品视频| 日韩一区二区三区在线视频| 亚洲精品看片| 欧美另类老肥妇| 日韩精品免费播放| 精品久久久久久中文字幕动漫| 精品欧美aⅴ在线网站| 激情综合五月婷婷| 黄色网址免费在线观看| 久久精品国产久精国产一老狼| 日本一区中文字幕| jizz一区二区三区| 久久久成人精品一区二区三区| 亚洲成人动漫在线播放| 狠狠狠色丁香婷婷综合激情| 中文字幕色婷婷在线视频| 99久久99久久精品| 久久天堂电影网| 国产精品素人视频| 日韩成人精品一区二区| 青草久久伊人| 欧美一区亚洲二区| 日韩精品福利网站| 91麻豆高清视频| 大陆精大陆国产国语精品| 91在线观看入口| 97se国产在线视频| 亚洲精品在线免费观看视频| 国产一区在线看| 成人影院网站ww555久久精品| 男女污污的视频| 国产精品免费视频久久久| 色综合久久久久综合| 久久久久一区| jizz亚洲女人高潮大叫| 国内外成人激情视频| 人妖精品videosex性欧美| 日韩欧美亚洲成人| 久久99国产精品久久| 秋霞无码一区二区| 国产精品视频一区二区久久| 狠狠操夜夜操| 97秋霞电影网| 国产网友自拍电影在线| 欧美性视频在线| 精品免费在线观看| 天堂va蜜桃一区二区三区漫画版| 第一福利在线视频| 中文字幕亚洲不卡| 在线中文字幕一区| 欧美性生活大片免费观看网址| 午夜视频一区二区| 国产精品国产三级国产aⅴ中文 | 精品极品在线| 春日野结衣av| 91久久久久久| 精品性高朝久久久久久久| 91丨国产丨九色丨pron| 天天躁日日躁成人字幕aⅴ| 18免费在线视频| 国产二区视频在线播放| 91大片在线观看| 日韩在线观看你懂的| 福利视频一区二区| 国产成人免费av在线| 俺要去色综合狠狠| 在线手机中文字幕| 欧美写真视频一区| 免费的一级黄色片| 亚洲999一在线观看www| 日韩精品中文在线观看| 亚洲一区二区在线免费观看视频| 免费欧美日韩国产三级电影| 青青草原在线亚洲| caoporn-草棚在线视频最| 写真福利片hd在线观看| 肉大捧一出免费观看网站在线播放| 国产精品99一区| 亚洲精品综合久久中文字幕| 欧美日韩日本国产| 久久婷婷久久一区二区三区| 99在线精品视频在线观看 | 日韩av大片免费看| 国产视频精品在线| 色av综合在线| 日本一区二区综合亚洲| 日本视频在线一区| 一区二区三区四区电影| 草草视频在线一区二区| 九色porny丨首页入口在线| 精品99又大又爽又硬少妇毛片| 男人亚洲天堂网| 亚洲午夜在线观看| 99热国产免费| 日本亚洲欧洲色α| 色七七影院综合| 精品捆绑美女sm三区 | 99re视频在线| 97av在线视频免费播放| 亚洲图片在区色| 欧美一级高清片| 91大神在线播放精品| 黄色在线一区| 色激情天天射综合网| 国产一区二区三区视频在线| 亚洲精品你懂的| 日韩在线视频免费观看| 污视频网站观看| 亚洲国产精品美女| 青青草精品视频在线|