内存的分配原则
對(duì)象的內(nèi)存分配,往大的方向上講,就是在堆上分配,少數(shù)情況下也可能會(huì)直接分配在老年代中,分配的規(guī)則并不是百分之百固定的,其細(xì)節(jié)決定于當(dāng)前使用的是哪種垃圾收集器組合,當(dāng)然還有虛擬機(jī)中與內(nèi)存相關(guān)的參數(shù)。垃圾收集器組合一般就是Serial+Serial Old和Parallel+Serial Old,前者是Client模式下的默認(rèn)垃圾收集器組合,后者是Server模式下的默認(rèn)垃圾收集器組合,文章使用對(duì)比學(xué)習(xí)法對(duì)比Client模式下和Server模式下同一條對(duì)象分配原則有什么區(qū)別。
?
TLAB
首先講講什么是TLAB。內(nèi)存分配的動(dòng)作,可以按照線程劃分在不同的空間之中進(jìn)行,即每個(gè)線程在Java堆中預(yù)先分配一小塊內(nèi)存,稱為本地線程分配緩沖(Thread Local Allocation Buffer,TLAB)。哪個(gè)線程需要分配內(nèi)存,就在哪個(gè)線程的TLAB上分配。虛擬機(jī)是否使用TLAB,可以通過-XX:+/-UseTLAB參數(shù)來設(shè)定。這么做的目的之一,也是為了并發(fā)創(chuàng)建一個(gè)對(duì)象時(shí),保證創(chuàng)建對(duì)象的線程安全性。TLAB比較小,直接在TLAB上分配內(nèi)存的方式稱為快速分配方式,而TLAB大小不夠,導(dǎo)致內(nèi)存被分配在Eden區(qū)的內(nèi)存分配方式稱為慢速分配方式
?
?
其他幾條原則
實(shí)際過程中我們可能使用的并不是上面的垃圾收集器的組合,可能使用ParNew垃圾收集器,可能使用G1垃圾收集器。場(chǎng)景很多,重要的是要在實(shí)際使用的時(shí)候有辦法知道使用的垃圾收集器對(duì)于對(duì)象分配有哪些原則,因?yàn)槔斫膺@些原則才是調(diào)優(yōu)的第一步。下面列舉一下對(duì)象分配的另外兩條原則:
1、長(zhǎng)期存活的對(duì)象將進(jìn)入老年代。Eden區(qū)中的對(duì)象在一次Minor GC后沒有被回收,則對(duì)象年齡+1,當(dāng)對(duì)象年齡達(dá)到“-XX:MaxTenuringThreshold”設(shè)置的值的時(shí)候,對(duì)象就會(huì)被晉升到老年代中
2、Survivor空間中相同年齡的所有對(duì)象大小總和大于Survivor空間的一半,年齡大于或等于該年齡的對(duì)象就可以直接進(jìn)入老年代,無須等到“-XX:MaxTenuringThreshold”設(shè)置要求的年齡
轉(zhuǎn)載于:https://www.cnblogs.com/tp123/p/6599574.html
總結(jié)
- 上一篇: 物联网笔记2
- 下一篇: MySQL基于SSL协议的主从复制