溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

簡(jiǎn)單了解Java垃圾回收器的種類

發(fā)布時(shí)間:2020-09-18 05:50:22 來(lái)源:腳本之家 閱讀:151 作者:mengwei 欄目:編程語(yǔ)言

在這篇教程中我們將學(xué)習(xí)幾種現(xiàn)有的垃圾回收器。在Java中,垃圾回收是一個(gè)自動(dòng)的進(jìn)程可以替代程序員進(jìn)行內(nèi)存的分配與回收這些復(fù)雜的工作。這篇是垃圾回 收教程系列的第三篇,在前面的第2部分我們看到了在Java中垃圾回收是如何工作的,那是篇有意思的文章,我推薦你去看一下。第一部分介紹了Java的垃圾回收,主要有JVM體系結(jié)構(gòu),堆內(nèi)存模型和一些Java術(shù)語(yǔ)。

Java有四種類型的垃圾回收器:

串行垃圾回收器(Serial Garbage Collector)
并行垃圾回收器(Parallel Garbage Collector)
并發(fā)標(biāo)記掃描垃圾回收器(CMS Garbage Collector)
G1垃圾回收器(G1 Garbage Collector)

簡(jiǎn)單了解Java垃圾回收器的種類

每種類型都有自己的優(yōu)勢(shì)與劣勢(shì)。重要的是,我們編程的時(shí)候可以通過JVM選擇垃圾回收器類型。我們通過向JVM傳遞參數(shù)進(jìn)行選擇。每種類型在很大程度上有所不同并且可以為我們提供完全不同的應(yīng)用程序性能。理解每種類型的垃圾回收器并且根據(jù)應(yīng)用程序選擇進(jìn)行正確的選擇是非常重要的。

1、串行垃圾回收器

串行垃圾回收器通過持有應(yīng)用程序所有的線程進(jìn)行工作。它為單線程環(huán)境設(shè)計(jì),只使用一個(gè)單獨(dú)的線程進(jìn)行垃圾回收,通過凍結(jié)所有應(yīng)用程序線程進(jìn)行工作,所以可能不適合服務(wù)器環(huán)境。它最適合的是簡(jiǎn)單的命令行程序。

通過JVM參數(shù)-XX:+UseSerialGC可以使用串行垃圾回收器。

2、并行垃圾回收器

并行垃圾回收器也叫做throughputcollector。它是JVM的默認(rèn)垃圾回收器。與串行垃圾回收器不同,它使用多線程進(jìn)行垃圾回收。相似的是,它也會(huì)凍結(jié)所有的應(yīng)用程序線程當(dāng)執(zhí)行垃圾回收的時(shí)候

3、并發(fā)標(biāo)記掃描垃圾回收器

并發(fā)標(biāo)記垃圾回收使用多線程掃描堆內(nèi)存,標(biāo)記需要清理的實(shí)例并且清理被標(biāo)記過的實(shí)例。并發(fā)標(biāo)記垃圾回收器只會(huì)在下面兩種情況持有應(yīng)用程序所有線程。

當(dāng)標(biāo)記的引用對(duì)象在tenured區(qū)域;

在進(jìn)行垃圾回收的時(shí)候,堆內(nèi)存的數(shù)據(jù)被并發(fā)的改變。

相比并行垃圾回收器,并發(fā)標(biāo)記掃描垃圾回收器使用更多的CPU來(lái)確保程序的吞吐量。如果我們可以為了更好的程序性能分配更多的CPU,那么并發(fā)標(biāo)記上掃描垃圾回收器是更好的選擇相比并發(fā)垃圾回收器。

通過JVM參數(shù)XX:+USeParNewGC打開并發(fā)標(biāo)記掃描垃圾回收器。

4、G1垃圾回收器

G1垃圾回收器適用于堆內(nèi)存很大的情況,他將堆內(nèi)存分割成不同的區(qū)域,并且并發(fā)的對(duì)其進(jìn)行垃圾回收。G1也可以在回收內(nèi)存之后對(duì)剩余的堆內(nèi)存空間進(jìn)行壓縮。并發(fā)掃描標(biāo)記垃圾回收器在STW情況下壓縮內(nèi)存。G1垃圾回收會(huì)優(yōu)先選擇第一塊垃圾最多的區(qū)域

通過JVM參數(shù)–XX:+UseG1GC使用G1垃圾回收器

Java8的新特性

在使用G1垃圾回收器的時(shí)候,通過JVM參數(shù)-XX:+UseStringDeduplication。我們可以通過刪除重復(fù)的字符串,只保留一個(gè)char[]來(lái)優(yōu)化堆內(nèi)存。這個(gè)選擇在Java8u20被引入。

我們給出了全部的四種Java垃圾回收器,需要根據(jù)應(yīng)用場(chǎng)景,硬件性能和吞吐量需求來(lái)決定使用哪一種。

垃圾回收的JVM配置

下面的JVM關(guān)鍵配置都與Java垃圾回收有關(guān)。

運(yùn)行的垃圾回收器類型

配置 描述
-XX:+UseSerialGC 串行垃圾回收器
-XX:+UseParallelGC 并行垃圾回收器
-XX:+UseConcMarkSweepGC 并發(fā)標(biāo)記掃描垃圾回收器
-XX:ParallelCMSThreads= 并發(fā)標(biāo)記掃描垃圾回收器 =為使用的線程數(shù)量
-XX:+UseG1GC G1垃圾回收器

GC的優(yōu)化配置

配置 描述
-Xms 初始化堆內(nèi)存大小
-Xmx 堆內(nèi)存最大值
-Xmn 新生代大小
-XX:PermSize 初始化永久代大小
-XX:MaxPermSize 永久代最大容量

使用JVM GC參數(shù)的例子

java -Xmx12m -Xms3m -Xmn1m -XX:PermSize=20m -XX:MaxPermSize=20m -XX:+UseSerialGC -jar java-application.jar

總結(jié)

以上就是本文關(guān)于簡(jiǎn)單了解Java垃圾回收器的種類的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI