真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

go語言有沒有gc

這篇文章主要介紹“go語言有沒有gc”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“go語言有沒有gc”文章能幫助大家解決問題。

在網站設計、做網站過程中,需要針對客戶的行業(yè)特點、產品特性、目標受眾和市場情況進行定位分析,以確定網站的風格、色彩、版式、交互等方面的設計方向。創(chuàng)新互聯(lián)還需要根據客戶的需求進行功能模塊的開發(fā)和設計,包括內容管理、前臺展示、用戶權限管理、數(shù)據統(tǒng)計和安全保護等功能。

go語言有gc。GC是指垃圾回收,是一種自動內存管理的機制;go語言支持GC,Go中對象內存空間的回收是通過GC機制來完成的。對于Go而言,Go的GC使用的是無分代(對象沒有代際之分)、不整理(回收過程中不對對象進行移動與整理)、并發(fā)(與用戶代碼并發(fā)執(zhí)行)的三色標記清掃算法。

GC機制是在Java語言被廣泛使用之后所火起來的,像后來的腳本語言Python都支持GC,GO也支持GC。

Go語言和C/C++語言的一個顯著的特點是Go中對象內存空間的回收是通過GC機制來完成的,不需要像C++一樣通過程序員的手動申請和釋放,所以Go中相對不容易出現(xiàn)內存泄漏。今天我們就來聊聊Go中的GC機制。

什么是GC,又有什么用?

GC,全稱 Garbage Collection,即垃圾回收,是一種自動內存管理的機制。

當程序向操作系統(tǒng)申請的內存不再需要時,垃圾回收主動將其回收并供其他代碼進行內存申請時候復用,或者將其歸還給操作系統(tǒng),這種針對內存級別資源的自動回收過程,即為垃圾回收。而負責垃圾回收的程序組件,即為垃圾回收器。

垃圾回收其實一個完美的 “Simplicity is Complicated” 的例子。一方面,程序員受益于 GC,無需操心、也不再需要對內存進行手動的申請和釋放操作,GC 在程序運行時自動釋放殘留的內存。另一方面,GC 對程序員幾乎不可見,僅在程序需要進行特殊優(yōu)化時,通過提供可調控的 API,對 GC 的運行時機、運行開銷進行把控的時候才得以現(xiàn)身。

通常,垃圾回收器的執(zhí)行過程被劃分為兩個半獨立的組件:

  • 賦值器(Mutator):這一名稱本質上是在指代用戶態(tài)的代碼。因為對垃圾回收器而言,用戶態(tài)的代碼僅僅只是在修改對象之間的引用關系,也就是在對象圖(對象之間引用關系的一個有向圖)上進行操作。

  • 回收器(Collector):負責執(zhí)行垃圾回收的代碼。

GC中的根對象

根對象在垃圾回收的術語中又叫做根集合,它是垃圾回收器在標記過程時最先檢查的對象,包括:

  • 全局變量:程序在編譯期就能確定的那些存在于程序整個生命周期的變量。

  • 執(zhí)行棧:每個 goroutine 都包含自己的執(zhí)行棧,這些執(zhí)行棧上包含棧上的變量及指向分配的堆內存區(qū)塊的指針。

  • 寄存器:寄存器的值可能表示一個指針,參與計算的這些指針可能指向某些賦值器分配的堆內存區(qū)塊。

GC的實現(xiàn)方式

所有的 GC 算法其存在形式可以歸結為追蹤(Tracing)和引用計數(shù)(Reference Counting)這兩種形式的混合運用。

  • 追蹤式 GC

    從根對象出發(fā),根據對象之間的引用信息,一步步推進直到掃描完畢整個堆并確定需要保留的對象,從而回收所有可回收的對象。Go、 Java、V8 對 JavaScript 的實現(xiàn)等均為追蹤式 GC。

  • 引用計數(shù)式 GC

    每個對象自身包含一個被引用的計數(shù)器,當計數(shù)器歸零時自動得到回收。因為此方法缺陷較多,在追求高性能時通常不被應用。Python、Objective-C 等均為引用計數(shù)式 GC。

目前比較常見的 GC 實現(xiàn)方式包括:

  • 追蹤式,分為多種不同類型,例如:

    • 標記清掃:從根對象出發(fā),將確定存活的對象進行標記,并清掃可以回收的對象。

    • 標記整理:為了解決內存碎片問題而提出,在標記過程中,將對象盡可能整理到一塊連續(xù)的內存上。

    • 增量式:將標記與清掃的過程分批執(zhí)行,每次執(zhí)行很小的部分,從而增量的推進垃圾回收,達到近似實時、幾乎無停頓的目的。

    • 增量整理:在增量式的基礎上,增加對對象的整理過程。

    • 分代式:將對象根據存活時間的長短進行分類,存活時間小于某個值的為年輕代,存活時間大于某個值的為老年代,永遠不會參與回收的對象為永久代。并根據分代假設(如果一個對象存活時間不長則傾向于被回收,如果一個對象已經存活很長時間則傾向于存活更長時間)對對象進行回收。

  • 引用計數(shù):根據對象自身的引用計數(shù)來回收,當引用計數(shù)歸零時立即回收。

Go中GC的實現(xiàn)方式

對于 Go 而言,Go 的 GC 使用的是無分代(對象沒有代際之分)、不整理(回收過程中不對對象進行移動與整理)、并發(fā)(與用戶代碼并發(fā)執(zhí)行)的三色標記清掃算法。

原因如下:

  • 對象整理的優(yōu)勢是解決內存碎片問題以及“允許”使用順序內存分配器。但 Go 運行時的分配算法基于 tcmalloc,基本上沒有碎片問題。并且順序內存分配器在多線程的場景下并不適用。Go 使用的是基于 tcmalloc 的現(xiàn)代內存分配算法,對對象進行整理不會帶來實質性的性能提升。

  • 分代 GC 依賴分代假設,即 GC 將主要的回收目標放在新創(chuàng)建的對象上(存活時間短,更傾向于被回收),而非頻繁檢查所有對象。但 Go 的編譯器會通過逃逸分析將大部分新生對象存儲在棧上(棧直接被回收),只有那些需要長期存在的對象才會被分配到需要進行垃圾回收的堆中。也就是說,分代 GC 回收的那些存活時間短的對象在 Go 中是直接被分配到棧上,當 goroutine 死亡后棧也會被直接回收,不需要 GC 的參與,進而分代假設并沒有帶來直接優(yōu)勢。并且 Go 的垃圾回收器與用戶代碼并發(fā)執(zhí)行,使得 STW 的時間與對象的代際、對象的 size 沒有關系。Go 團隊更關注于如何更好地讓 GC 與用戶代碼并發(fā)執(zhí)行(使用適當?shù)?CPU 來執(zhí)行垃圾回收),而非減少停頓時間這一單一目標上。

關于“go語言有沒有gc”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識,可以關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點。


本文標題:go語言有沒有gc
URL鏈接:http://weahome.cn/article/pegdos.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部