新聞中心
Java內(nèi)存區(qū)域

十余年的左權(quán)網(wǎng)站建設(shè)經(jīng)驗(yàn),針對設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。營銷型網(wǎng)站的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整左權(quán)建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。成都創(chuàng)新互聯(lián)從事“左權(quán)網(wǎng)站設(shè)計(jì)”,“左權(quán)網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
Q:Java虛擬機(jī)規(guī)范將JVM虛擬機(jī)所管理的內(nèi)存分為幾部分?如果是多選題,估計(jì)會給一些不在里面的,例如直接內(nèi)存。
A:程序計(jì)數(shù)器、java虛擬機(jī)棧、本地方法棧、方法區(qū)、堆。
java對象在內(nèi)存上的分配:
§ GC策略
Q:java使用根搜索算法來確定對象是否存貨,哪些對象可以作為GC Roots?
A:
- 虛擬機(jī)棧(棧幀中的本地變量表)中的引用的對象
- 方法區(qū)中的類靜態(tài)屬性引用的對象
- 方法區(qū)中的常量引用的對象
- 本地方法棧中JNI(Native方法)的引用對象
Q:標(biāo)記清除、標(biāo)記整理、復(fù)制算法哪個(gè)塊?
A:復(fù)制算法較快。
3個(gè)算法含義如下:
Q:SerialOld用的是什么算法?
A:標(biāo)記整理算法,屬于處理老年代算法。
各收集器的變化圖如下,主要關(guān)注一下變化和區(qū)別,
Q:fullGC 會發(fā)生在老年代區(qū)還是新生代區(qū)?
A: 會發(fā)生在老年代區(qū)。相反,minorGC一般發(fā)送在新生代區(qū)。
新生代、老生代以及minorGC、fullGC的發(fā)生流程如下:
Q:方法區(qū)里的class對象(即類對象)什么時(shí)候會被回收?
A:所有實(shí)例都被回收、對應(yīng)classLoader也被回收、class對象不會再被引用或者反射(這個(gè)咋確定?當(dāng)初書里看到的,沒懂)
§ finalized與GC
Q:什么時(shí)候會調(diào)用對象的finalized方法
A:JVM啟動垃圾回收,且該對象要被回收時(shí)。
finalized應(yīng)該更多是規(guī)范吧,很多規(guī)范里都要求我們不要自己實(shí)現(xiàn)finalized了,畢竟不確定性太大。
§ Java虛擬機(jī)GC參數(shù)配置
突然想起來當(dāng)初看java虛擬機(jī)時(shí),把那些參數(shù)給跳過了,感覺記不住。
但現(xiàn)在發(fā)現(xiàn)還是得學(xué)的,趕緊惡補(bǔ)一下。
Q:
-client和-server的對比
()啟動較快
()性能和內(nèi)存管理效率高(注意啟動快和性能好不是一回事)
桌面應(yīng)用一般使用(), 服務(wù)器一般使用()
A:
(-clien)啟動較快
(-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)存大小?
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)閉針對類對象的gc功能的是()
可用于減少gc的程序停頓時(shí)間的是()
用于輸出gc相關(guān)日志的是()
A:
可用于關(guān)閉針對類對象的gc功能的是(-Xnoclassgc)
可用于減少gc的程序停頓時(shí)間的是(-Xincgc)
用于輸出gc相關(guān)日志的是(-Xloggc:file)
Q:-verbose 一般是用于什么的?
A:
查詢gc問題。
- -verbose:class 輸出jvm載入類的相關(guān)信息,當(dāng)jvm報(bào)告說找不到類或者類沖突時(shí)可此進(jìn)行診斷。
- -verbose:gc 輸出每次GC的相關(guān)情況,后面會有更詳細(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來控制這塊內(nèi)存的大小,jvm在啟動的時(shí)候會根據(jù)-XX:PermSize初始化分配一塊連續(xù)的內(nèi)存塊,這樣的話,如果-XX:PermSize設(shè)置過大,可能會很浪費(fèi)。而Max如果設(shè)置小了,可能會omm。
Q:-XX:MetaspaceSize和-XX:MaxMetaspaceSize又是什么內(nèi)存?
A:
元數(shù)據(jù)區(qū)內(nèi)存。java8引入的,用于替代上面的perm區(qū)。
無論-XX:MetaspaceSize和-XX:MaxMetaspaceSize兩個(gè)參數(shù)如何設(shè)置,隨著類加載越來越多不斷擴(kuò)容調(diào)整,直到MetaspaceSize(如果沒有配置就是默認(rèn)20.8m)觸發(fā)FGC,上限是-XX:MaxMetaspaceSize,默認(rèn)是幾乎無窮大
當(dāng)前名稱:垃圾回收你懂,Java垃圾回收你懂嗎?
標(biāo)題來源:http://fisionsoft.com.cn/article/djdogpg.html


咨詢
建站咨詢
