JVM培訓之一些GC演算法的理論知識

来源:https://www.cnblogs.com/pengx/archive/2018/09/16/9658097.html
-Advertisement-
Play Games

很精彩的一次內部分享,介紹了大部分的GC演算法理論知識,JVM博大精深,本篇文章只是結合本次內部分享總結的一些理論知識,如果有大佬有疑問,歡迎留言指出! Concurrent:併發,程式一邊運行一邊做GC Parallel:並行,一塊區域,一個人做清掃,需要100s,但是把區域分成兩塊,用兩個人掃,時 ...


很精彩的一次內部分享,介紹了大部分的GC演算法理論知識,JVM博大精深,本篇文章只是結合本次內部分享總結的一些理論知識,如果有大佬有疑問,歡迎留言指出!

Concurrent:併發,程式一邊運行一邊做GC

Parallel:並行,一塊區域,一個人做清掃,需要100s,但是把區域分成兩塊,用兩個人掃,時間就縮短了一半;所以GC演算法有並行的,有不是並行的,這些都是可以根據自己的實際業務去選擇的,只有最適合自己的GC演算法;

Stop The World:簡稱STW,某些GC演算法當中,當需要做GC的時候,程式是必須停下來的,程式就是一個終止狀態,當GC結束之後再恢復;Java的GC很多時候都是STW,舉一個簡單的慄子,一邊掃地一邊嗑瓜子,這樣的話是永遠掃不幹凈的,記憶體的使用率就不是很高,當然STW有一個很大的缺點,就是程式必須終止,如果說做一次GC用時太長,需要十幾秒或者一分鐘或更多,那肯定是無法忍受的,這就需要GC調優來完成,通過演算法把時間控制在最短,讓用戶無感知;

root set:公集合,GC的時候會確定現在哪些對象還是存活的,

Generation GC:分代GC,先說一代GC,比方說現在有一個2G的記憶體區域,那麼需要GC的時候,需要把整塊記憶體區域2G遍歷一次,來做GC,這是一個很複雜的過程,需要判斷這麼多的對象是否引用或者被引用,可想而知耗時肯定會很長;以老王的經驗,1G記憶體做一次full GC停頓時間在1-3s,100G記憶體做一次full GC,停頓時間在1-3min,也就是說這幾分鐘程式什麼都幹不了,肯定是無法接受的;所以產出了分代GC,把一個區域分成幾個部分,年輕代1,年輕代2,和年老代。比方說程式開始運行,新產生的對象放在年輕代1,裝滿之後,結合copy演算法,從root節點出發,可能真正存活的對象只有很少一部分,那麼我們只把這部分對象拷貝到年輕代2裡面,然後將年輕代1區域全部清掃掉,這個copy演算法非常高效,但前提是需要程式的對象大部分都是用完一次就可以扔掉的,不然的話,存活的對象太多了,copy演算法就變得很低效了;所以copy演算法的效率取決於剩餘的對象,剩餘的對象越多,效率越低,剩餘的對象越少,效率越高;

RefCount:引用計數演算法,當有指針指向這個對象的時候,就把計數器+1,當不指向這個對象的時候把計數器-1,當這個對象的計數器為0的時候,這個對象的記憶體就可以釋放掉了,Python就是用的這個演算法,官方的python流派就是用的這個演算法,微軟的com組建結構也是用的這個引用計數演算法;這個演算法兩個缺點:效率低,因為訪問對象是一個很頻繁的操作,這樣頻繁做++;掃不幹凈,迴圈列表,a->b->c,其實外部沒有引用,但是內部有互相引用,其實abc都是垃圾;

MarkSweep:標記清除演算法,有很多對象,從公集合出發找其他的對象,是活的對象就做標記,標記的過程中,程式是不能跑的,當標記完了之後,沒有被標記的對象,就都可以釋放掉了,但是清掃之後的記憶體區域會變得千瘡百孔,再分配記憶體的時候,需要在這些記憶體中,找一個合適自己的記憶體區域;

MarkCompact:標記壓縮演算法,可以理解是標記清除演算法的一個升級版,同樣是在活對象上標記,但是它會選一個活對象作為一個端,把另外標記的活對象往這一端擠,這樣被釋放的區域就會是一大塊的;

Safepoint:當代碼運行到某個點,這個點可以做GC,這個點就叫safepoint,做GC的時候,所有的線程都需要停下來,就是所有的線程需要跑到這個安全點,跑到這個點的時候,Java虛擬機會生成一條指令,這個指令會讓這個線程訪問一個記憶體地址,這也是為了快速響應;因為線程停下來做別的事情非常耗性能;

Reference:強引用,強引用是我只要引用你,你就不會被垃圾回收;當然還有WeakReference弱引用和軟引用SoftReference等;

Java虛擬機的幾個GC演算法:

  年輕代:Serial:串列,STW特性

      ParNew:多線程,也是STW

      ParScavenge:多線程,同樣是STW,是ParNew升級版

 

  年老代:CMS:試圖平衡停頓時間,這個演算法的過程為:InitialMark->CCMark->Remark->CCSweep

      SerialOld:MarkCompact演算法上面提到過的

      ParOld:同樣是MarkCompact演算法,是SerialOld升級版

年輕代和年老代GC演算法是可以組合的,除了部分;

ZGC:Java11版本發佈推出,管理TB級記憶體,GC時間控制在10ms;

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • sass的嵌套包括兩種: 1、選擇器的嵌套。(最常用到) 指的是在一個選擇器中嵌套另一個選擇器來實現繼承,從而增強了sass文件的結構性和可讀性。 在選擇器嵌套中,可以使用&表示父元素選擇器 scss.style css.style 2、屬性嵌套 指的是有些屬性擁有同一個開始單詞,如border-w ...
  • @if判斷 @if可一個條件單獨使用,也可以和@else結合多條件使用 scss.style css.style 三目判斷 語法為:if($condition, $if_true, $if_false) 。 三個參數分別表示:條件,條件為真的值,條件為假的值。 scss.style css.styl ...
  • 一、摘要 小程式中我們會經常使用到this.data與this.setData。其中this.data是用來獲取頁面data對象的,而this.setData是用來更新界面的。那麼他們之間的區別與聯繫你真的搞懂了嗎? 二、正文 this.data可以獲取頁面data對象,但是它返回的對象到底是新的對 ...
  • 工作上使用到element-ui tree 組件,主要功能是要實現節點拖拽和置頂,通過自定義內容方法(render-content)渲染樹代碼如下~ 1 <template> 2 <div class="sortDiv"> 3 <el-tree :data="sortData" draggable ...
  • 你可能不知道的setInterval的坑 之前印象中一直記得setInterval有一些坑,但是一直不是很清楚那些坑是什麼。今天去摸索了下之後,決定來做個記錄以免自己忘記,也希望讓更多人瞭解到這個坑。 坑的地方 1. setInterval會無視代碼的錯誤。就算遇到了錯誤,它還是會一直迴圈下去,不會 ...
  • 第一步先安裝nmp 在node.js的官網下載即可。 第二步 直接安裝剛下載好的node.js即可,(這裡建議不要修改node.js的安裝路徑),傻瓜式直接下一步即可 檢測是否安裝成功: 在cmd的控制台直接輸入node -v 如果出現這樣的界面恭喜你node.js安裝成功 (利用 win + r ...
  • 開發者的javascript造詣取決於對【動態】和【非同步】這兩個詞的理解水平。 一. 一道考察非同步知識的面試題 題目是這樣的,要求寫出下麵代碼的輸出: 如果沒有詳細鑽研過非同步隊列,答對的可能性很低。題目的考察點很明確,就是 中最核心的特點之一的【非同步】,瞭解了原理以後,你就會明白 中聲稱的“無阻塞” ...
  • 首發鏈接:https://bbs.huaweicloud.com/blogs/70f69ca4953111e89fc57ca23e93a89f 《一統江湖的大前端》系列是自己的前端學習筆記,旨在介紹javascript在非網頁開發領域的應用案例和發現各類好玩的js庫,不定期更新。如果你對前端的理解還 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...