一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Golang - 圖解Golang的GC垃圾回收算法

圖解Golang的GC垃圾回收算法

2020-05-23 11:54RyuGou Golang

這篇文章主要介紹了圖解Golang的GC垃圾回收算法,詳細的介紹了三種經典的算法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

雖然GolangGC自打一開始,就被人所詬病,但是經過這么多年的發展,Golang的GC已經改善了非常多,變得非常優秀了。

以下是Golang GC算法的里程碑:

  • v1.1 STW
  • v1.3 Mark STW, Sweep 并行
  • v1.5 三色標記法
  • v1.8 hybrid write barrier

經典的GC算法有三種: 引用計數(reference counting)標記-清掃(mark & sweep)復制收集(Copy and Collection)

Golang的GC算法主要是基于 標記-清掃(mark and sweep) 算法,并在此基礎上做了改進。因此,在此主要介紹一下 標記-清掃(mark and sweep)算法 ,關于 引用計數(reference counting)復制收集(copy and collection) 可自行百度。

標記-清掃(Mark And Sweep)算法

此算法主要有兩個主要的步驟:

  • 標記(Mark phase)
  • 清除(Sweep phase)

第一步,找出不可達的對象,然后做上標記。

第二步,回收標記好的對象。

操作非常簡單,但是有一點需要額外注意: mark and sweep 算法在執行的時候,需要程序暫停!即 stop the world

也就是說,這段時間程序會卡在哪兒。故中文翻譯成 卡頓

我們來看一下圖解:

開始標記,程序暫停。程序和對象的此時關系是這樣的:

圖解Golang的GC垃圾回收算法

然后開始標記,process找出它所有可達的對象,并做上標記。如下圖所示:

圖解Golang的GC垃圾回收算法

標記完了之后,然后開始清除未標記的對象:

圖解Golang的GC垃圾回收算法

然后 垃圾 清除了,變成了下圖這樣。

圖解Golang的GC垃圾回收算法

最后,停止暫停,讓程序繼續跑。然后循環重復這個過程,直到 process 生命周期結束。

標記-清掃(Mark And Sweep)算法存在什么問題?

標記-清掃(Mark And Sweep)算法 這種算法雖然非常的簡單,但是還存在一些問題:

  • STW,stop the world;讓程序暫停,程序出現卡頓。
  • 標記需要掃描整個heap
  • 清除數據會產生heap碎片

這里面最重要的問題就是:mark-and-sweep 算法會暫停整個整個程序。

Go是如何面對并這個問題的呢?

三色并發標記法

我們先來看看Golang的三色標記法的大體流程。

首先:程序創建的對象都標記為白色。

圖解Golang的GC垃圾回收算法

gc開始:掃描所有可到達的對象,標記為灰色

圖解Golang的GC垃圾回收算法

從灰色對象中找到其引用對象標記為灰色,把灰色對象本身標記為黑色

圖解Golang的GC垃圾回收算法

監視對象中的內存修改,并持續上一步的操作,直到灰色標記的對象不存在

圖解Golang的GC垃圾回收算法

此時,gc回收白色對象。

圖解Golang的GC垃圾回收算法

最后,將所有黑色對象變為白色,并重復以上所有過程。

圖解Golang的GC垃圾回收算法

好了,大體的流程就是這樣的,讓我們回到剛才的問題:Go是如何解決 標記-清除(mark and sweep) 算法中的卡頓(stw,stop the world)問題的呢?

gc和用戶邏輯如何并行操作?

標記-清除(mark and sweep)算法的STW(stop the world)操作,就是runtime把所有的線程全部凍結掉,所有的線程全部凍結意味著用戶邏輯是暫停的。這樣所有的對象都不會被修改了,這時候去掃描是絕對安全的。

Go如何減短這個過程呢?標記-清除(mark and sweep)算法包含兩部分邏輯:標記和清除。

我們知道Golang三色標記法中最后只剩下的黑白兩種對象,黑色對象是程序恢復后接著使用的對象,如果不碰觸黑色對象,只清除白色的對象,肯定不會影響程序邏輯。所以: 清除操作和用戶邏輯可以并發。

標記操作和用戶邏輯也是并發的,用戶邏輯會時常生成對象或者改變對象的引用,那么標記和用戶邏輯如何并發呢?

process新生成對象的時候,GC該如何操作呢?不會亂嗎?

我們看如下圖,在此狀態下:process程序又新生成了一個對象,我們設想會變成這樣:

圖解Golang的GC垃圾回收算法

但是這樣顯然是不對的,因為按照三色標記法的步驟,這樣新生成的對象A最后會被清除掉,這樣會影響程序邏輯。

Golang為了解決這個問題,引入了 寫屏障 這個機制。

寫屏障:該屏障之前的寫操作和之后的寫操作相比,先被系統其它組件感知。

通俗的講:就是在gc跑的過程中,可以監控對象的內存修改,并對對象進行重新標記。(實際上也是超短暫的stw,然后對對象進行標記)

在上述情況中, 新生成的對象,一律都標位灰色!
即下圖:

圖解Golang的GC垃圾回收算法

那么,灰色或者黑色對象的引用改為白色對象的時候,Golang是該如何操作的?

看如下圖,一個黑色對象引用了曾經標記的白色對象。

圖解Golang的GC垃圾回收算法

這時候,寫屏障機制被觸發,向GC發送信號,GC重新掃描對象并標位灰色。

圖解Golang的GC垃圾回收算法

因此,gc一旦開始,無論是創建對象還是對象的引用改變,都會先變為灰色。

參考文獻:

Golang's Real-time GC in Theory and Practice

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://juejin.im/post/5c8525666fb9a049ea39c3e6

 

延伸 · 閱讀

精彩推薦
  • Golanggolang如何使用struct的tag屬性的詳細介紹

    golang如何使用struct的tag屬性的詳細介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細介紹,從例子說起,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看...

    Go語言中文網11352020-05-21
  • Golanggo日志系統logrus顯示文件和行號的操作

    go日志系統logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統logrus顯示文件和行號的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • Golanggolang json.Marshal 特殊html字符被轉義的解決方法

    golang json.Marshal 特殊html字符被轉義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉義的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • GolangGolang通脈之數據類型詳情

    Golang通脈之數據類型詳情

    這篇文章主要介紹了Golang通脈之數據類型,在編程語言中標識符就是定義的具有某種意義的詞,比如變量名、常量名、函數名等等,Go語言中標識符允許由...

    4272021-11-24
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
  • Golanggolang的httpserver優雅重啟方法詳解

    golang的httpserver優雅重啟方法詳解

    這篇文章主要給大家介紹了關于golang的httpserver優雅重啟的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,...

    helight2992020-05-14
  • GolangGolang中Bit數組的實現方式

    Golang中Bit數組的實現方式

    這篇文章主要介紹了Golang中Bit數組的實現方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨尊11682021-06-09
主站蜘蛛池模板: 操的我好爽| 无人知晓小说姜璟免费阅读 | 高清视频在线播放ww | 国产三级精品久久三级国专区 | 999精品视频这里只有精品 | 久久国产主播福利在线 | 日韩欧美高清 | 久久久精品3d动漫一区二区三区 | 精品在线小视频 | 俄罗斯妈妈k8影院在线观看 | 国产色综合久久五月色婷婷中文 | 男女被爆动漫羞羞动漫 | 99久久一香蕉国产线看观看 | 污污的动态图合集 | 亚洲国产自 | 美女模特被c免费视频 | 日本xxx片免费高清在线 | 国产午夜亚洲精品不卡 | 美女叽叽 | 丝瓜视频成人在线观看 | 国产传媒天美果冻 | 国产伦久视频免费观看视频 | chinese男同志videos| 国产成人综合网亚洲欧美在线 | 国产精品日本一区二区三区在线看 | 亚洲成a人不卡在线观看 | 四虎免费影院4hu永久免费 | 国产一卡二卡3卡4卡更新 | jm漫天堂破解版 | 毛片在线免费观看网站 | 精品视频入口 | 暗卫调教女主肉高h | 日本老师动漫 | 北条麻妃黑人 | 日本老妇人乱视频 | 亚洲大片在线观看 | 高中生喷水喷浆 | 亚洲冬月枫中文字幕在线看 | 91香蕉国产在线观看人员 | 女烈受刑重口小说 | 鬼畜重口高h合集长短篇 |