<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    stone2083

    jdk gc簡(jiǎn)介

    常用的GC算法:
    1)標(biāo)記非活動(dòng)對(duì)象
    --何為非活動(dòng)對(duì)象,通俗的講,就是無引用的對(duì)象。
    • 追蹤root對(duì)象算法: 深度追蹤root對(duì)象,將heap中所有被引用到的root做標(biāo)志,所有未被標(biāo)志的對(duì)象視為非活動(dòng)對(duì)象,所占用的空間視為非活動(dòng)內(nèi)存。
    2)清理非活動(dòng)對(duì)象
    • Copy算法:          
    • 方法:將內(nèi)存分為兩個(gè)區(qū)域(from space和to space)。所有的對(duì)象分配內(nèi)存都分配到from space。在清理非活動(dòng)對(duì)象階段,把所有標(biāo)志為活動(dòng)的對(duì)象,copy到to space,之后清楚from space空間。然后互換from sapce和to space的身份。既原先的from space變成to sapce,原先的to space變成from space。每次清理,重復(fù)上述過程。
    • 優(yōu)點(diǎn):copy算法不理會(huì)非活動(dòng)對(duì)象,copy數(shù)量?jī)H僅取決為活動(dòng)對(duì)象的數(shù)量。并且在copy的同時(shí),整理了heap空間,即,to space的空間使用始終是連續(xù)的,內(nèi)存使用效率得到提高。
    • 缺點(diǎn):劃分from space和to space,內(nèi)存的使用率是1/2。
    •   Compaction算法
      • 方法:在清理非活動(dòng)對(duì)象階段,刪除非活動(dòng)對(duì)象占用內(nèi)存,并且把活動(dòng)對(duì)象向heap的底部移動(dòng),直到所有的活動(dòng)對(duì)象被移到heap的一側(cè)。
      • 優(yōu)點(diǎn):無須劃分from sapce和to space,提高內(nèi)存的使用率。并且compaction后的內(nèi)存空間也是連續(xù)分配的。
      • 缺點(diǎn):該算法相對(duì)比較復(fù)雜。
    sun jdk gc介紹:
    在減少gc之前,先來看看來自IBM的一組統(tǒng)計(jì)數(shù)據(jù):
    98%的java對(duì)象,在創(chuàng)建之后不久就變成了非活動(dòng)對(duì)象;只有2%的對(duì)象,會(huì)在長(zhǎng)時(shí)間一直處于活動(dòng)狀態(tài)。

    如果能對(duì)這兩種對(duì)象區(qū)分對(duì)象,那么會(huì)提交GC的效率。在sun jdk gc中(具體的說,是在jdk1.4之后的版本),提出了不同生命周期的GC策略。
    • young generation
      • 生命周期很短的對(duì)象,歸為young generation。由于生命周期很短,這部分對(duì)象在gc的時(shí)候,很大部分的對(duì)象已經(jīng)成為非活動(dòng)對(duì)象。因此針對(duì)young  generation的對(duì)象,采用copy算法,只需要將少量的存活下來的對(duì)象copy到to space。存活的對(duì)象數(shù)量越少,那么copy算法的效率越高。
      • young generation的gc稱為minor gc。經(jīng)過數(shù)次minor gc,依舊存活的對(duì)象,將被移出young generation,移到tenured generation(下面將會(huì)介紹)

      • young generation分為:
        • eden:每當(dāng)對(duì)象創(chuàng)建的時(shí)候,總是被分配在這個(gè)區(qū)域
        • survivor1:copy算法中的from space
        • survivor2:copy算法中的to sapce (備注:其中survivor1和survivor2的身份在每次minor gc后被互換)
      • minor gc的時(shí)候,會(huì)把eden+survivor1(2)的對(duì)象copy到survivor2(1)去。
    • tenured generation
      • 生命周期較常的對(duì)象,歸入到tenured generation。一般是經(jīng)過多次minor gc,還 依舊存活的對(duì)象,將移入到tenured generation。(當(dāng)然,在minor gc中如果存活的對(duì)象的超過survivor的容量,放不下的對(duì)象會(huì)直接移入到tenured generation)
      • tenured generation的gc稱為major gc,就是通常說的full gc。
      • 采用compactiion算法。由于tenured generaion區(qū)域比較大,而且通常對(duì)象生命周期都比較常,compaction需要一定時(shí)間。所以這部分的gc時(shí)間比較長(zhǎng)。
      • minor gc可能引發(fā)full gc。當(dāng)eden+from space的空間大于tenured generation區(qū)的剩余空間時(shí),會(huì)引發(fā)full gc。這是悲觀算法,要確保eden+from space的對(duì)象如果都存活,必須有足夠的tenured generation空間存放這些對(duì)象。
    • Permanet Generation:
      • 該區(qū)域比較穩(wěn)定,主要用于存放classloader信息,比如類信息和method信息。
      • 對(duì)于spring hibernate這些需要?jiǎng)討B(tài)類型支持的框架,這個(gè)區(qū)域需要足夠的空間。

    這部分內(nèi)容相對(duì)比較理論,可以結(jié)合jstat,jmap等命令(當(dāng)然也可以使用jconsole,jprofile,gciewer等工具),觀察jdk gc的情況。

    posted on 2008-03-15 17:11 stone2083 閱讀(2020) 評(píng)論(2)  編輯  收藏 所屬分類: java

    Feedback

    # re: jdk gc簡(jiǎn)介 2008-03-24 09:33 倪煒

    很不錯(cuò),最近在看這個(gè)東西,sun的文檔看的不是很清楚,這里寫的很明白了。  回復(fù)  更多評(píng)論   

    # re: jdk gc簡(jiǎn)介 2008-07-03 22:09 stone2083

    這么朋友實(shí)在是過獎(jiǎng)了.
    我僅僅記錄了我對(duì)jdk gc的淺薄理解.
    sun的文檔,比我這邊是詳細(xì)多了.  回復(fù)  更多評(píng)論   

    主站蜘蛛池模板: 国产亚洲精彩视频| 亚洲精品久久无码| 亚洲国产精品成人久久久| 亚洲精品动漫免费二区| 91精品国产免费久久久久久青草 | 国产成人免费高清在线观看 | 59pao成国产成视频永久免费 | 亚洲国产成人精品无码久久久久久综合| 国产日韩亚洲大尺度高清| 亚洲黄页网在线观看| 99热在线日韩精品免费| 免费观看的av毛片的网站| 亚洲男人都懂得羞羞网站| 美女免费视频一区二区三区| 亚洲黄色免费电影| 亚洲女人影院想要爱| 毛片基地免费视频a| 亚洲国产精品日韩在线| 搡女人免费视频大全| 亚洲国产美女在线观看| 噼里啪啦电影在线观看免费高清| 亚洲一本到无码av中文字幕| 免费在线观看h片| 亚洲资源在线观看| 免费精品久久天干天干| 国产啪亚洲国产精品无码 | 少妇无码一区二区三区免费| 亚洲综合区小说区激情区| 在线亚洲精品视频| 亚洲日韩欧洲乱码AV夜夜摸| 一区二区三区免费视频观看 | 日韩精品无码免费专区午夜| 亚洲欧洲日产国码在线观看| 国产精品色午夜免费视频| 成人免费一区二区三区| 久久亚洲AV永久无码精品| 97久久免费视频| 亚洲嫩草影院在线观看| 国产亚洲精品免费| 日韩在线观看视频免费| 亚洲日韩涩涩成人午夜私人影院|