轉自:https://segmentfault.com/a/1190000006214497
在Java中為對象配置設定和釋放記憶體空間都是由垃圾回收線程自動執行完成的。和C語言不一樣的是Java程式員不需要手動寫垃圾回收相關的代碼。這是使得Java如此流行,同時也是Java能幫助程式員寫出更好的Java應用的優點之一。
本文将會介紹各種不同類型的Java垃圾回收器。垃圾回收是Java用來将程式員從配置設定和釋放記憶體的瑣事中解放出來的自動過程。
Java有四種類型的垃圾回收器,
Serial Garbage Collector
Parallel Garbage Collector
CMS Garbage Collector
G1 Garbage Collector
這四種類型的垃圾回收器都有各自的優點和缺點。最重要的是程式員可以選擇JVM使用哪種類型的垃圾回收器。我們可以通過傳遞不同的JVM參數來設定使用哪一個。各個垃圾回收器在不同應用場景下的效率會有很大的差異。是以了解各種不同類型的垃圾回收器以及它們的應用場景是非常重要的。
串行垃圾回收器控制所有的應用線程。它是為單線程場景設計的,隻使用一個線程來執行垃圾回收工作。它暫停所有應用線程來執行垃圾回收工作的方式不适用于伺服器的應用環境。它最适用的是簡單的指令行程式。
使用-XX:+UseSerialGCJVM參數來開啟使用串行垃圾回收器。
并行垃圾回收器也稱作基于吞吐量的回收器。它是JVM的預設垃圾回收器。與Serial不同的是,它使用多個線程來執行垃圾回收工作。和Serial回收器一樣,它在執行垃圾回收工作是也需要暫停所有應用線程。
并發标記清除(Concurrent Mark Sweep,CMS)垃圾回收器,使用多個線程來掃描堆記憶體并标記可被清除的對象,然後清除标記的對象。CMS垃圾回收器隻在下面這兩種情形下暫停工作線程,
在老年代中标記引用對象的時候
在做垃圾回收的過程中堆記憶體中有變化發生
對比與并行垃圾回收器,CMS回收器使用更多的CPU來保證更高的吞吐量。如果我們可以有更多的CPU用來提升性能,那麼CMS垃圾回收器是比并行回收器更好的選擇。
使用-XX:+UseParNewGCJVM參數來開啟使用CMS垃圾回收器。
G1垃圾回收器應用于大的堆記憶體空間。它将堆記憶體空間劃分為不同的區域,對各個區域并行地做回收工作。G1在回收記憶體空間後還立即堆空閑空間做整合工作以減少碎片。CMS卻是在全部停止(stop the world,STW)時執行記憶體整合工作。對于不同的區域G1根據垃圾的數量決定優先級。
使用-XX:UseG1GCJVM參數來開啟使用G1垃圾回收器。
Java 8 的優化
在使用G1垃圾回收器是,開啟使用-XX:+UseStringDeduplacatonJVM參數。它會通過把重複的String值移動到同一個char[]數組來優化堆記憶體占用。這是Java 8 u 20引入的選項。
以上給出的四個Java垃圾回收器,在什麼時候使用哪一個去決于應用場景,硬體配置和吞吐量要求。
下面是些主要的與Java垃圾回收相關的JVM選項。
Type of Garbage Collector to run
選項
描述
-XX:+UseSerialGC
串行垃圾回收器
-XX:+UseParallelGC
并行垃圾回收器
-XX:+UseConcMarkSweepGC
CMS垃圾回收器
-XX:ParallesCMSThread=
CMS垃圾回收器–使用的線程數量
-XX:UseG1GC
G1垃圾回收器
GC 優化選項
-Xms
初始堆記憶體大小
-Xmx
最大堆記憶體大小
-Xmn
年輕代的大小
-XX:PermSize
初始永久代的大小
-XX:MaxPermSize
最大的永久代的大小
Example Usage of JVM GC Options