自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

詳解Java GC的工作原理

開發(fā) 后端
JVM學(xué)習(xí)筆記之JVM內(nèi)存管理和JVM垃圾回收的概念,JVM內(nèi)存結(jié)構(gòu)由堆、棧、本地方法棧、方法區(qū)等部分組成,另外JVM分別對新生代和舊生代采用不同的垃圾回收機(jī)制。

JVM學(xué)習(xí)筆記之JVM內(nèi)存管理和JVM垃圾回收的概念,JVM內(nèi)存結(jié)構(gòu)由堆、棧、本地方法棧、方法區(qū)等部分組成,另外JVM分別對新生代和舊生代采用不同的垃圾回收機(jī)制。

首先來看一下JVM內(nèi)存結(jié)構(gòu),它是由堆、棧、本地方法棧、方法區(qū)等部分組成,結(jié)構(gòu)圖如下所示。

JVM學(xué)習(xí)筆記 JVM內(nèi)存管理和JVM垃圾回收

JVM內(nèi)存組成結(jié)構(gòu)

JVM內(nèi)存結(jié)構(gòu)由堆、棧、本地方法棧、方法區(qū)等部分組成,結(jié)構(gòu)圖如下所示:

 

JVM內(nèi)存組成結(jié)構(gòu)

 

1)堆

所有通過new創(chuàng)建的對象的內(nèi)存都在堆中分配,其大小可以通過-Xmx和-Xms來控制。堆被劃分為新生代和舊生代,新生代又被進(jìn)一步劃分為Eden和Survivor區(qū),***Survivor由FromSpace和ToSpace組成,結(jié)構(gòu)圖如下所示:

 

JVM內(nèi)存結(jié)構(gòu)之堆

 

新生代。新建的對象都是用新生代分配內(nèi)存,Eden空間不足的時候,會把存活的對象轉(zhuǎn)移到Survivor中,新生代大小可以由-Xmn來控制,也可以用-XX:SurvivorRatio來控制Eden和Survivor的比例舊生代。用于存放新生代中經(jīng)過多次垃圾回收仍然存活的對象

2)棧

每個線程執(zhí)行每個方法的時候都會在棧中申請一個棧幀,每個棧幀包括局部變量區(qū)和操作數(shù)棧,用于存放此次方法調(diào)用過程中的臨時變量、參數(shù)和中間結(jié)果

3)本地方法棧

用于支持native方法的執(zhí)行,存儲了每個native方法調(diào)用的狀態(tài)

4)方法區(qū)

存放了要加載的類信息、靜態(tài)變量、final類型的常量、屬性和方法信息。JVM用持久代(PermanetGeneration)來存放方法區(qū),可通過-XX:PermSize和-XX:MaxPermSize來指定最小值和***值。介紹完了JVM內(nèi)存組成結(jié)構(gòu),下面我們再來看一下JVM垃圾回收機(jī)制。

JVM垃圾回收機(jī)制

JVM分別對新生代和舊生代采用不同的垃圾回收機(jī)制

新生代的GC:

新生代通常存活時間較短,因此基于Copying算法來進(jìn)行回收,所謂Copying算法就是掃描出存活的對象,并復(fù)制到一塊新的完全未使用的空間中,對應(yīng)于新生代,就是在Eden和FromSpace或ToSpace之間copy。新生代采用空閑指針的方式來控制GC觸發(fā),指針保持***一個分配的對象在新生代區(qū)間的位置,當(dāng)有新的對象要分配內(nèi)存時,用于檢查空間是否足夠,不夠就觸發(fā)GC。當(dāng)連續(xù)分配對象時,對象會逐漸從eden到survivor,***到舊生代,

用javavisualVM來查看,能明顯觀察到新生代滿了后,會把對象轉(zhuǎn)移到舊生代,然后清空繼續(xù)裝載,當(dāng)舊生代也滿了后,就會報outofmemory的異常,如下圖所示:

 

outofmemory的異常

 

在執(zhí)行機(jī)制上JVM提供了串行GC(SerialGC)、并行回收GC(ParallelScavenge)和并行GC(ParNew)

1)串行GC

在整個掃描和復(fù)制過程采用單線程的方式來進(jìn)行,適用于單CPU、新生代空間較小及對暫停時間要求不是非常高的應(yīng)用上,是client級別默認(rèn)的GC方式,可以通過-XX:+UseSerialGC來強制指定

2)并行回收GC

在整個掃描和復(fù)制過程采用多線程的方式來進(jìn)行,適用于多CPU、對暫停時間要求較短的應(yīng)用上,是server級別默認(rèn)采用的GC方式,可用-XX:+UseParallelGC來強制指定,用-XX:ParallelGCThreads=4來指定線程數(shù)

3)并行GC

與舊生代的并發(fā)GC配合使用

舊生代的GC:

舊生代與新生代不同,對象存活的時間比較長,比較穩(wěn)定,因此采用標(biāo)記(Mark)算法來進(jìn)行回收,所謂標(biāo)記就是掃描出存活的對象,然后再進(jìn)行回收未被標(biāo)記的對象,回收后對用空出的空間要么進(jìn)行合并,要么標(biāo)記出來便于下次進(jìn)行分配,總之就是要減少內(nèi)存碎片帶來的效率損耗。在執(zhí)行機(jī)制上JVM提供了串行GC(SerialMSC)、并行GC(parallelMSC)和并發(fā)GC(CMS),具體算法細(xì)節(jié)還有待進(jìn)一步深入研究。

以上各種GC機(jī)制是需要組合使用的,指定方式由下表所示:

 

GC機(jī)制組合使用

 
 
責(zé)任編輯:金賀 來源: JavaEye博客
相關(guān)推薦

2009-06-15 10:43:45

Java程序員Java程序GC

2019-11-27 14:41:50

Java技術(shù)語言

2020-10-16 08:30:00

foreach編程語言C#

2019-09-02 14:53:53

JVM內(nèi)存布局GC

2020-01-06 10:58:18

JvmGC機(jī)制虛擬機(jī)

2009-07-09 14:01:22

JVM工作原理

2010-09-26 08:50:11

JVM工作原理

2010-06-18 15:49:41

ACPId服務(wù)

2009-11-09 08:53:21

ASP.NET緩存

2018-06-01 09:17:52

區(qū)塊鏈以太坊

2009-06-03 09:11:03

Hibernate工作原理體系結(jié)構(gòu)

2020-10-30 09:00:00

JavaScriptJavaScript引前端

2017-05-18 15:02:36

AndroidGC原理JVM內(nèi)存回收

2022-06-08 09:56:46

靜態(tài)鏈接Linux命令

2019-12-06 11:18:07

LinuxCPU架構(gòu)

2021-09-07 06:40:25

AndroidLiveData原理

2011-05-25 11:26:46

LVS-DRLVS

2015-01-27 14:47:52

http協(xié)議

2011-12-07 14:25:33

JavaNIO

2015-11-04 09:23:17

JavaServlet工作原理
點贊
收藏

51CTO技術(shù)棧公眾號