JVM内存区域划分总结
發(fā)現(xiàn)網(wǎng)上有兩個(gè)版本的JVM內(nèi)存劃分,一個(gè)是按照《深入理解JVM虛擬機(jī)》上的版本,包含程序計(jì)數(shù)器等,按照是否線程共享劃分。
另一個(gè)我覺得更好記一些,也更適合我自己,在這里記錄一下。
首先上思維導(dǎo)圖:
一個(gè)個(gè)來說道吧。
堆內(nèi)存 heap
堆內(nèi)存主要被劃分為新生代和老年代(叫法不一,差不多的意思)。JVM默認(rèn)Yong和Old分配比例為1:2,即新生代的內(nèi)存大小為堆內(nèi)存的1/3。
(調(diào)整參數(shù):–XX:NewRatio)
基本上所有對象實(shí)例都在堆中創(chuàng)建,因此堆內(nèi)存經(jīng)常發(fā)生GC回收操作。新的對象首先分配在Eden區(qū),兩個(gè)Surviior區(qū)僅作為Eden區(qū)的緩沖使用。每次GC回收一次,對象的age值就+1,當(dāng)Survivor區(qū)對象age值大于15時(shí),就被轉(zhuǎn)移到老年代。
(age值調(diào)整參數(shù):-XX:MaxTenuringThreshold)
新生代下又劃分為三個(gè)區(qū),即Eden Space,To Survivor ,From Survivor。新生代占用堆內(nèi)存的1/3,而三個(gè)區(qū)的內(nèi)存占用情況如下圖:
?
?
新生代中,Eden、from、to的默認(rèn)比例為8:1:1,一般來說,當(dāng)Eden區(qū)內(nèi)存將要被占滿時(shí),才會(huì)進(jìn)入其中一個(gè)Survivor區(qū)。JVM每次只會(huì)使用一塊Survivor區(qū)來為對象服務(wù)。所以,不論何時(shí),都存在一個(gè)空閑的Survivor區(qū)域
(調(diào)整參數(shù):–XX:SurvivorRatio )
?
老年代存放JVM認(rèn)為生命周期較長的對象,內(nèi)存大小也比較大,GC回收相對來說不太頻繁,所以分配給老年區(qū)的內(nèi)存大小為堆內(nèi)存的2/3
堆內(nèi)存回收規(guī)則:
當(dāng)一個(gè)對象小于Eden區(qū)內(nèi)存時(shí),直接放入Eden區(qū),若大于Eden并小于老年代,則直接放入老年代。若大于老年代,則直接內(nèi)存溢出
如此分區(qū)的目的:
新生代由于對象產(chǎn)生的比較多并且大都是朝生夕滅的,所以直接采用標(biāo)記-清理算法。而老年代生命力強(qiáng),采用復(fù)制算法,針對不同情況使用不同算法
?
非堆區(qū)
?
轉(zhuǎn)載于:https://www.cnblogs.com/yuan-zhou/p/11311210.html
總結(jié)
以上是生活随笔為你收集整理的JVM内存区域划分总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Practical Lessons fr
- 下一篇: [Spring cloud 一步步实现广