垃圾回收你懂,Java垃圾回收你懂嗎?
摘要:在用 C 之類的編程語(yǔ)言時(shí),程序員需要自己手動(dòng)分配和釋放內(nèi)存。而 Java 不一樣,它有垃圾回收器,釋放內(nèi)存由回收器負(fù)責(zé)。本文接下來(lái)將介紹Java垃圾收集的知識(shí)原理。
java內(nèi)存區(qū)域
Q:Java虛擬機(jī)規(guī)范將JVM虛擬機(jī)所管理的內(nèi)存分為幾部分?如果是多選題,估計(jì)會(huì)給一些不在里面的,例如直接內(nèi)存。
A:程序計(jì)數(shù)器、java虛擬機(jī)棧、本地方法棧、方法區(qū)、堆。

java對(duì)象在內(nèi)存上的分配:

§?GC策略
Q:java使用根搜索算法來(lái)確定對(duì)象是否存貨,哪些對(duì)象可以作為GC Roots?
A:
虛擬機(jī)棧(棧幀中的本地變量表)中的引用的對(duì)象
方法區(qū)中的類靜態(tài)屬性引用的對(duì)象
方法區(qū)中的常量引用的對(duì)象
本地方法棧中JNI(Native方法)的引用對(duì)象
Q:標(biāo)記清除、標(biāo)記整理、復(fù)制算法哪個(gè)塊?
A:復(fù)制算法較快。
3個(gè)算法含義如下:

Q:SerialOld用的是什么算法?
A:標(biāo)記整理算法,屬于處理老年代算法。
各收集器的變化圖如下,主要關(guān)注一下變化和區(qū)別,


Q:fullGC 會(huì)發(fā)生在老年代區(qū)還是新生代區(qū)?
A: 會(huì)發(fā)生在老年代區(qū)。相反,minorGC一般發(fā)送在新生代區(qū)。
新生代、老生代以及minorGC、fullGC的發(fā)生流程如下:

Q:方法區(qū)里的class對(duì)象(即類對(duì)象)什么時(shí)候會(huì)被回收?
A:所有實(shí)例都被回收、對(duì)應(yīng)classLoader也被回收、class對(duì)象不會(huì)再被引用或者反射(這個(gè)咋確定?當(dāng)初書(shū)里看到的,沒(méi)懂)
§?finalized與GC
Q:什么時(shí)候會(huì)調(diào)用對(duì)象的finalized方法
A:JVM啟動(dòng)垃圾回收,且該對(duì)象要被回收時(shí)。
finalized應(yīng)該更多是規(guī)范吧,很多規(guī)范里都要求我們不要自己實(shí)現(xiàn)finalized了,畢竟不確定性太大。
§?Java虛擬機(jī)GC參數(shù)配置
突然想起來(lái)當(dāng)初看java虛擬機(jī)時(shí),把那些參數(shù)給跳過(guò)了,感覺(jué)記不住。
但現(xiàn)在發(fā)現(xiàn)還是得學(xué)的,趕緊惡補(bǔ)一下。
Q:
-client和-server的對(duì)比
()啟動(dòng)較快
()性能和內(nèi)存管理效率高(注意啟動(dòng)快和性能好不是一回事)
桌面應(yīng)用一般使用(), 服務(wù)器一般使用()
A:
(-clien)啟動(dòng)較快
(-server)性能和內(nèi)存管理效率高
桌面應(yīng)用一般使用(-clien), 服務(wù)器一般使用(-server)
有4個(gè)跟內(nèi)存相關(guān)的參數(shù)
-Xmn -Xms -Xmx -Xss
回答下面的問(wèn)題:
Q:
用于配置java初始堆內(nèi)存的是()
A:
-Xms。
-X、memory、size ,內(nèi)存大小
Q:
用于配置java堆的最大值的是()
A:
-Xmx。
-X、memory、max
最大內(nèi)存

Q:如果不設(shè)置,-Xms和-Xmx的大小分別默認(rèn)是多少?
A:
不設(shè)置的話,二者相等,默認(rèn)是 物理內(nèi)存/64(小于1G)
Q:用于配置新生代內(nèi)存大小的最大值是:()
你問(wèn)我什么是新生代內(nèi)存?
就是下面這個(gè),1個(gè)E區(qū)加2個(gè)S區(qū)的這個(gè)內(nèi)存大小
A:
-Xmn。
-X、memory、new
相類似的還有-XX:NewSize 和 -XX:MaxNewSize。
Q:如何根據(jù)上面的參數(shù)計(jì)算老年代內(nèi)存大小?
A:
Xmx的值(堆最大值)- Xmn的值(新生代內(nèi)存)
Q:用于配置線程棧內(nèi)存的是()?替代的還有哪個(gè)參數(shù)?
A:
-Xss。另一個(gè)是-XX:ThreadStackSize
-Xss指 -X stack size
有下面3個(gè)和gc相關(guān)的參數(shù)
-Xnoclassgc -Xincgc -Xloggc:file
回答以下問(wèn)題:
Q:
可用于關(guān)閉針對(duì)類對(duì)象的gc功能的是()
可用于減少gc的程序停頓時(shí)間的是()
用于輸出gc相關(guān)日志的是()
A:
可用于關(guān)閉針對(duì)類對(duì)象的gc功能的是(-Xnoclassgc)
可用于減少gc的程序停頓時(shí)間的是(-Xincgc)
用于輸出gc相關(guān)日志的是(-Xloggc:file)
Q:-verbose 一般是用于什么的?
A:
查詢gc問(wèn)題。
-verbose:class 輸出jvm載入類的相關(guān)信息,當(dāng)jvm報(bào)告說(shuō)找不到類或者類沖突時(shí)可此進(jìn)行診斷。
-verbose:gc 輸出每次GC的相關(guān)情況,后面會(huì)有更詳細(xì)的介紹。
-verbose:jni 輸出native方法調(diào)用的相關(guān)情況,一般用于診斷jni調(diào)用錯(cuò)誤信息。
Q: -XX:PermSize和-XX:MaxPermSize設(shè)置的是什么內(nèi)存?
A:
方法區(qū)的內(nèi)存。就是最開(kāi)始那個(gè)圖里的這個(gè)

通過(guò)配置-XX:PermSize以及-XX:MaxPermSize來(lái)控制這塊內(nèi)存的大小,jvm在啟動(dòng)的時(shí)候會(huì)根據(jù)-XX:PermSize初始化分配一塊連續(xù)的內(nèi)存塊,這樣的話,如果-XX:PermSize設(shè)置過(guò)大,可能會(huì)很浪費(fèi)。而Max如果設(shè)置小了,可能會(huì)omm。
Q:-XX:MetaspaceSize和-XX:MaxMetaspaceSize又是什么內(nèi)存?
A:
元數(shù)據(jù)區(qū)內(nèi)存。java8引入的,用于替代上面的perm區(qū)。
無(wú)論-XX:MetaspaceSize和-XX:MaxMetaspaceSize兩個(gè)參數(shù)如何設(shè)置,隨著類加載越來(lái)越多不斷擴(kuò)容調(diào)整,直到MetaspaceSize(如果沒(méi)有配置就是默認(rèn)20.8m)觸發(fā)FGC,上限是-XX:MaxMetaspaceSize,默認(rèn)是幾乎無(wú)窮大
本文分享自華為云社區(qū)《Java云服務(wù)開(kāi)發(fā)知識(shí)學(xué)習(xí)之 java垃圾收集》,原文作者:breakDraw 。
本文鏈接:https://blog.csdn.net/devcloud/article/details/111719989
end
*版權(quán)聲明:轉(zhuǎn)載文章和圖片均來(lái)自公開(kāi)網(wǎng)絡(luò),版權(quán)歸作者本人所有,推送文章除非無(wú)法確認(rèn),我們都會(huì)注明作者和來(lái)源。如果出處有誤或侵犯到原作者權(quán)益,請(qǐng)與我們聯(lián)系刪除或授權(quán)事宜。
長(zhǎng)按識(shí)別圖中二維碼
關(guān)注獲取更多資訊
不點(diǎn)關(guān)注,我們哪來(lái)故事?

點(diǎn)個(gè)再看,你最好看
