亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

圖解Golang的GC垃圾回收算法

 更新時(shí)間:2019年03月13日 10:27:28   作者:RyuGou  
這篇文章主要介紹了圖解Golang的GC垃圾回收算法,詳細(xì)的介紹了三種經(jīng)典的算法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

雖然Golang的GC自打一開始,就被人所詬病,但是經(jīng)過(guò)這么多年的發(fā)展,Golang的GC已經(jīng)改善了非常多,變得非常優(yōu)秀了。

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

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

經(jīng)典的GC算法有三種: 引用計(jì)數(shù)(reference counting) 、 標(biāo)記-清掃(mark & sweep)復(fù)制收集(Copy and Collection) 。

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

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

此算法主要有兩個(gè)主要的步驟:

  • 標(biāo)記(Mark phase)
  • 清除(Sweep phase)

第一步,找出不可達(dá)的對(duì)象,然后做上標(biāo)記。

第二步,回收標(biāo)記好的對(duì)象。

操作非常簡(jiǎn)單,但是有一點(diǎn)需要額外注意: mark and sweep 算法在執(zhí)行的時(shí)候,需要程序暫停!即 stop the world 。

也就是說(shuō),這段時(shí)間程序會(huì)卡在哪兒。故中文翻譯成 卡頓 。

我們來(lái)看一下圖解:

開始標(biāo)記,程序暫停。程序和對(duì)象的此時(shí)關(guān)系是這樣的:

然后開始標(biāo)記,process找出它所有可達(dá)的對(duì)象,并做上標(biāo)記。如下圖所示:

標(biāo)記完了之后,然后開始清除未標(biāo)記的對(duì)象:

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

最后,停止暫停,讓程序繼續(xù)跑。然后循環(huán)重復(fù)這個(gè)過(guò)程,直到 process 生命周期結(jié)束。

標(biāo)記-清掃(Mark And Sweep)算法存在什么問(wèn)題?

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

  • STW,stop the world;讓程序暫停,程序出現(xiàn)卡頓。
  • 標(biāo)記需要掃描整個(gè)heap
  • 清除數(shù)據(jù)會(huì)產(chǎn)生heap碎片

這里面最重要的問(wèn)題就是:mark-and-sweep 算法會(huì)暫停整個(gè)整個(gè)程序。

Go是如何面對(duì)并這個(gè)問(wèn)題的呢?

三色并發(fā)標(biāo)記法

我們先來(lái)看看Golang的三色標(biāo)記法的大體流程。

首先:程序創(chuàng)建的對(duì)象都標(biāo)記為白色。

gc開始:掃描所有可到達(dá)的對(duì)象,標(biāo)記為灰色

從灰色對(duì)象中找到其引用對(duì)象標(biāo)記為灰色,把灰色對(duì)象本身標(biāo)記為黑色

監(jiān)視對(duì)象中的內(nèi)存修改,并持續(xù)上一步的操作,直到灰色標(biāo)記的對(duì)象不存在

此時(shí),gc回收白色對(duì)象。

最后,將所有黑色對(duì)象變?yōu)榘咨⒅貜?fù)以上所有過(guò)程。

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

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

標(biāo)記-清除(mark and sweep)算法的STW(stop the world)操作,就是runtime把所有的線程全部?jī)鼋Y(jié)掉,所有的線程全部?jī)鼋Y(jié)意味著用戶邏輯是暫停的。這樣所有的對(duì)象都不會(huì)被修改了,這時(shí)候去掃描是絕對(duì)安全的。

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

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

標(biāo)記操作和用戶邏輯也是并發(fā)的,用戶邏輯會(huì)時(shí)常生成對(duì)象或者改變對(duì)象的引用,那么標(biāo)記和用戶邏輯如何并發(fā)呢?

process新生成對(duì)象的時(shí)候,GC該如何操作呢?不會(huì)亂嗎?

我們看如下圖,在此狀態(tài)下:process程序又新生成了一個(gè)對(duì)象,我們?cè)O(shè)想會(huì)變成這樣:

但是這樣顯然是不對(duì)的,因?yàn)榘凑杖珮?biāo)記法的步驟,這樣新生成的對(duì)象A最后會(huì)被清除掉,這樣會(huì)影響程序邏輯。

Golang為了解決這個(gè)問(wèn)題,引入了 寫屏障 這個(gè)機(jī)制。

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

通俗的講:就是在gc跑的過(guò)程中,可以監(jiān)控對(duì)象的內(nèi)存修改,并對(duì)對(duì)象進(jìn)行重新標(biāo)記。(實(shí)際上也是超短暫的stw,然后對(duì)對(duì)象進(jìn)行標(biāo)記)

在上述情況中, 新生成的對(duì)象,一律都標(biāo)位灰色!
即下圖:

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

看如下圖,一個(gè)黑色對(duì)象引用了曾經(jīng)標(biāo)記的白色對(duì)象。

這時(shí)候,寫屏障機(jī)制被觸發(fā),向GC發(fā)送信號(hào),GC重新掃描對(duì)象并標(biāo)位灰色。

因此,gc一旦開始,無(wú)論是創(chuàng)建對(duì)象還是對(duì)象的引用改變,都會(huì)先變?yōu)榛疑?/p>

參考文獻(xiàn):

Golang's Real-time GC in Theory and Practice

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

相關(guān)文章

  • Go語(yǔ)言使用字符串的幾個(gè)技巧分享

    Go語(yǔ)言使用字符串的幾個(gè)技巧分享

    這篇文章中小編將給出一些Go語(yǔ)言在處理字符串方面的技巧,對(duì)大家學(xué)習(xí)Go語(yǔ)言具有一定的參考借鑒價(jià)值,下面一起看看吧。
    2016-09-09
  • Go?Web編程添加服務(wù)器錯(cuò)誤和訪問(wèn)日志

    Go?Web編程添加服務(wù)器錯(cuò)誤和訪問(wèn)日志

    這篇文章主要為大家介紹了Go?Web編程添加服務(wù)器錯(cuò)誤日志和訪問(wèn)日志的示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • golang限流庫(kù)兩個(gè)大bug(半年之久無(wú)人提起)

    golang限流庫(kù)兩個(gè)大bug(半年之久無(wú)人提起)

    最近我的同事在使用uber-go/ratelimit[1]這個(gè)限流庫(kù)的時(shí)候,遇到了兩個(gè)大?bug,這兩個(gè)?bug?都是在這個(gè)庫(kù)的最新版本(v0.3.0)中存在的,而這個(gè)版本從?7?月初發(fā)布都已經(jīng)過(guò)半年了,都沒人提?bug,難道大家都沒遇到過(guò)么
    2023-12-12
  • 解析Go語(yǔ)言編程中的struct結(jié)構(gòu)

    解析Go語(yǔ)言編程中的struct結(jié)構(gòu)

    這篇文章主要介紹了Go語(yǔ)言編程中的struct結(jié)構(gòu),是Go語(yǔ)言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-10-10
  • Go?Gin框架優(yōu)雅重啟和停止實(shí)現(xiàn)方法示例

    Go?Gin框架優(yōu)雅重啟和停止實(shí)現(xiàn)方法示例

    Web應(yīng)用程序中,有時(shí)需要重啟或停止服務(wù)器,無(wú)論是因?yàn)楦麓a還是進(jìn)行例行維護(hù),這時(shí)需要保證應(yīng)用程序的可用性和數(shù)據(jù)的一致性,就需要優(yōu)雅地關(guān)閉和重啟應(yīng)用程序,即不丟失正在處理的請(qǐng)求和不拒絕新的請(qǐng)求,本文將詳解如何在Go語(yǔ)言中使用Gin這個(gè)框架實(shí)現(xiàn)優(yōu)雅的重啟停止
    2024-01-01
  • Golang巧用defer進(jìn)行錯(cuò)誤處理的方法

    Golang巧用defer進(jìn)行錯(cuò)誤處理的方法

    錯(cuò)誤處理是程序的重要組成部分,有效且優(yōu)雅的處理錯(cuò)誤是大多數(shù)程序員的追求,下面這篇文章主要給大家介紹了關(guān)于Golang中巧用defer進(jìn)行錯(cuò)誤處理的方法,文中通過(guò)示例介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • Go語(yǔ)言實(shí)現(xiàn)LRU算法的核心思想和實(shí)現(xiàn)過(guò)程

    Go語(yǔ)言實(shí)現(xiàn)LRU算法的核心思想和實(shí)現(xiàn)過(guò)程

    這篇文章主要介紹了Go語(yǔ)言實(shí)現(xiàn)LRU算法的核心思想和實(shí)現(xiàn)過(guò)程,LRU算法是一種常用的緩存淘汰策略,它的核心思想是如果一個(gè)數(shù)據(jù)在最近一段時(shí)間內(nèi)沒有被訪問(wèn)到,那么在將來(lái)它被訪問(wèn)的可能性也很小,因此可以將其淘汰,感興趣想要詳細(xì)了解可以參考下文
    2023-05-05
  • go高并發(fā)時(shí)append方法偶現(xiàn)錯(cuò)誤解決分析

    go高并發(fā)時(shí)append方法偶現(xiàn)錯(cuò)誤解決分析

    這篇文章主要為大家介紹了go高并發(fā)時(shí)append方法偶現(xiàn)錯(cuò)誤解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • Go官方限流器的用法詳解

    Go官方限流器的用法詳解

    限流器是提升服務(wù)穩(wěn)定性的非常重要的組件,本文主要介紹了Go官方限流器的用法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • B站新一代 golang規(guī)則引擎gengine基礎(chǔ)語(yǔ)法

    B站新一代 golang規(guī)則引擎gengine基礎(chǔ)語(yǔ)法

    這篇文章主要為大家介紹了B站新一代 golang規(guī)則引擎gengine基礎(chǔ)語(yǔ)法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12

最新評(píng)論