您好,登錄后才能下訂單哦!
這篇文章主要介紹“如何理解Java垃圾回收”,在日常操作中,相信很多人在如何理解Java垃圾回收問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何理解Java垃圾回收”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
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)初書里看到的,沒懂)
§ 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ù)給跳過了,感覺記不住。
但現(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
回答下面的問題:
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)存大小的最大值是:()
你問我什么是新生代內(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)存大?。?/p>
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
回答以下問題:
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問題。
-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)存。就是最開始那個(gè)圖里的這個(gè)
通過配置-XX:PermSize以及-XX:MaxPermSize來(lái)控制這塊內(nèi)存的大小,jvm在啟動(dòng)的時(shí)候會(huì)根據(jù)-XX:PermSize初始化分配一塊連續(xù)的內(nèi)存塊,這樣的話,如果-XX:PermSize設(shè)置過大,可能會(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(如果沒有配置就是默認(rèn)20.8m)觸發(fā)FGC,上限是-XX:MaxMetaspaceSize,默認(rèn)是幾乎無(wú)窮大
到此,關(guān)于“如何理解Java垃圾回收”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
免責(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)容。