java gc种类_Java GC系列(3):垃圾回收器种类
Java有四種類型的垃圾回收器:
串行垃圾回收器(Serial Garbage Collector) 并行垃圾回收器(Parallel Garbage Collector) 并發標記掃描垃圾回收器(CMS Garbage Collector) G1垃圾回收器(G1 Garbage Collector)
每種類型都有自己的優勢與劣勢。重要的是,我們編程的時候可以通過JVM選擇垃圾回收器類型。我們通過向JVM傳遞參數進行選擇。每種類型在很大程度上有 所不同并且可以為我們提供完全不同的應用程序性能。理解每種類型的垃圾回收器并且根據應用程序選擇進行正確的選擇是非常重要的。
1、串行垃圾回收器
串行垃圾回收器通過持有應用程序所有的線程進行工作。它為單線程環境設計,只使用一個單獨的線程進行垃圾回收,通過凍結所有應用程序線程進行工作,所以可能不適合服務器環境。它最適合的是簡單的命令行程序。
通過JVM參數-XX:+UseSerialGC可以使用串行垃圾回收器。
2、并行垃圾回收器
并行垃圾回收器也叫做 throughput collector 。它是JVM的默認垃圾回收器。與串行垃圾回收器不同,它使用多線程進行垃圾回收。相似的是,它也會凍結所有的應用程序線程當執行垃圾回收的時候
3、并發標記掃描垃圾回收器
并發標記垃圾回收使用多線程掃描堆內存,標記需要清理的實例并且清理被標記過的實例。并發標記垃圾回收器只會在下面兩種情況持有應用程序所有線程。
當標記的引用對象在tenured區域; 在進行垃圾回收的時候,堆內存的數據被并發的改變。 相比并行垃圾回收器,并發標記掃描垃圾回收器使用更多的CPU來確保程序的吞吐量。如果我們可以為了更好的程序性能分配更多的CPU,那么并發標記上掃描垃圾回收器是更好的選擇相比并發垃圾回收器。
通過JVM參數 XX:+USeParNewGC 打開并發標記掃描垃圾回收器。
4、G1垃圾回收器
G1垃圾回收器適用于堆內存很大的情況,他將堆內存分割成不同的區域,并且并發的對其進行垃圾回收。G1也可以在回收內存之后對剩余的堆內存空間進行壓縮。并發掃描標記垃圾回收器在STW情況下壓縮內存。G1垃圾回收會優先選擇第一塊垃圾最多的區域
通過JVM參數 –XX:+UseG1GC 使用G1垃圾回收器
Java 8 的新特性
在使用G1垃圾回收器的時候,通過 JVM參數 -XX:+UseStringDeduplication 。 我們可以通過刪除重復的字符串,只保留一個char[]來優化堆內存。這個選擇在Java 8 u 20被引入。
我們給出了全部的四種Java垃圾回收器,需要根據應用場景,硬件性能和吞吐量需求來決定使用哪一種。
垃圾回收的JVM配置
下面的JVM關鍵配置都與Java垃圾回收有關。
運行的垃圾回收器類型
配置 描述
-XX:+UseSerialGC 串行垃圾回收器 -XX:+UseParallelGC 并行垃圾回收器 -XX:+UseConcMarkSweepGC 并發標記掃描垃圾回收器 -XX:ParallelCMSThreads= 并發標記掃描垃圾回收器 =為使用的線程數量 -XX:+UseG1GC G1垃圾回收器 GC的優化配置
配置 描述 -Xms 初始化堆內存大小 -Xmx 堆內存最大值 -Xmn 新生代大小 -XX:PermSize 初始化永久代大小 -XX:MaxPermSize 永久代最大容量
使用JVM GC參數的例子
java -Xmx12m -Xms3m -Xmn1m -XX:PermSize=20m -XX:MaxPermSize=20m -XX:+UseSerialGC -jar java-application.jar
在Java垃圾回收教程的下一部分,我們將會用一個Java程序演示如何監視和分析垃圾回收。
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的java gc种类_Java GC系列(3):垃圾回收器种类的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: cookie获取java_java中如何
- 下一篇: java美元兑换,(Java实现) 美元