本篇內(nèi)容介紹了“java堆的內(nèi)存模型介紹”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)建站!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了普定免費(fèi)建站歡迎大家使用!
根據(jù)對象存活的特點(diǎn)以及使垃圾回收產(chǎn)生算法產(chǎn)生最大的收益,將堆區(qū)分為兩大塊,一個(gè)是Old區(qū),一個(gè)是Young區(qū)。Young區(qū)分為兩大塊,一個(gè)是Survivor區(qū)(S0+S1),一塊是Eden區(qū)。S0和S1一樣大,也可以叫From和To。
一般情況下,新創(chuàng)建的對象都會被分配到Eden區(qū),一些特殊的大的對象會直接分配到Old區(qū)。
比如有對象A,B,C等創(chuàng)建在Eden區(qū),但是Eden區(qū)的內(nèi)存空間肯定有限,比如有100M,假如已經(jīng)使用了
100M或者達(dá)到一個(gè)設(shè)定的臨界值,這時(shí)候就需要對Eden內(nèi)存空間進(jìn)行清理,即垃圾收集(GarbageCollect),
這樣的GC我們稱之為MinorGC,MinorGC指得是Young區(qū)的GC。經(jīng)過GC之后,有些對象就會被清理掉,有些對象可能還存活著,對于存活著的對象需要將其復(fù)制到Survivor區(qū),然后再清空Eden區(qū)中的這些對象。
下面根據(jù)垃圾收集算法
詳細(xì)講解下為什么要分為surivor0和surivor1,難道一個(gè)survivor區(qū)不行嗎?
假設(shè)只有一個(gè)s0區(qū),eden區(qū)回收之后,一部分對象存放到了s0區(qū),此時(shí)eden區(qū)空間全部釋放,內(nèi)存都是連續(xù)的。但是因?yàn)閟0區(qū)也會進(jìn)行垃圾回收,它有一部分存活的對象進(jìn)入到了Old區(qū),還有一部分對象存活留下來,這時(shí)候s0區(qū)就產(chǎn)生了內(nèi)存碎片,為了使s0區(qū)的內(nèi)存空間相對連續(xù),再分配一個(gè)s1區(qū),大小和s0一樣,每次垃圾回收的時(shí)候,將eden區(qū)和s0區(qū)存活的對象移動到s1區(qū),這樣永遠(yuǎn)都能保證s0或者s1的內(nèi)存空間是連續(xù)的。當(dāng)然,這樣的情況下會使得s0或者s1區(qū)有一個(gè)空間永遠(yuǎn)為空,浪費(fèi)10%的內(nèi)存空間,當(dāng)然為了最大化的利用young區(qū),這樣的浪費(fèi)是被接受的。所以,young區(qū)一次GC流程是這樣的:在同一個(gè)時(shí)間點(diǎn)上,S0和S1只能有一個(gè)區(qū)有數(shù)據(jù),另外一個(gè)是空的。假設(shè)s0區(qū)有數(shù)據(jù),此時(shí)進(jìn)行一次GC操作,s0區(qū)中對象的年齡就會+1,而Eden區(qū)中所有存活的對象會被復(fù)制到是s1區(qū),s0區(qū)中還能存活的對象會有兩個(gè)去處。若對象年齡達(dá)到之前設(shè)置好的年齡閾值,此時(shí)對象會被移動到Old區(qū),Eden區(qū)和s0區(qū)沒有達(dá)到閾值的對象會被復(fù)制到s1區(qū),s0區(qū)將又會變?yōu)榭盏摹?/p>
“java堆的內(nèi)存模型介紹”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!