青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Lyt
posts - 16,comments - 61,trackbacks - 0

      太久沒有更新blog了,慚愧下先,下邊進(jìn)入正題。

      最近在實現(xiàn)一個閹割版的函數(shù)式語言(編譯器已完成,虛擬機(jī)在憋的過程中,之后會發(fā)帖),希望內(nèi)存管理的部分由虛擬機(jī)來完成,而不是由客戶自己折騰,這樣顯然可以降低客戶使用這門語言的難度,比如不需要擔(dān)心內(nèi)存泄漏,減少內(nèi)存運(yùn)用不當(dāng)?shù)腷ug,這里客戶只管放心地一直申請內(nèi)存就行,不再需要手工釋放內(nèi)存(如果讓客戶選擇是否自己釋放都行,會提高難度,起碼得做個平衡樹放著這些申請的內(nèi)存地址便于查找,這里先偷懶)。

      首先講一下虛擬機(jī)的內(nèi)存管理機(jī)制。眾所周知,頻繁地申請和釋放內(nèi)存會大大降低效率,所以我們可以在虛擬機(jī)運(yùn)行一開始的時候就統(tǒng)一申請內(nèi)存,虛擬機(jī)運(yùn)行結(jié)束在統(tǒng)一釋放內(nèi)存。如果中間有某些內(nèi)存已經(jīng)不需要再次使用,繼續(xù)占著茅坑不拉屎是非常不道德的,于是需要對此做點(diǎn)事情,造成內(nèi)存已釋放的“假象”。這里強(qiáng)調(diào)一下,虛擬機(jī)知道哪塊內(nèi)存正在使用、哪塊內(nèi)存不需再用就行了,實際上程序吃的內(nèi)存還是沒有減少。聲明一下,下文提到的申請和釋放內(nèi)存講的都是“假象”。

      如何實現(xiàn)這個機(jī)制呢?本能地想到引用計數(shù),記錄下到底有多少個對象引用這塊內(nèi)存,如果引用計數(shù)為0就釋放內(nèi)存。后來才意識到引用計數(shù)是行不通的,萬一有環(huán)形數(shù)據(jù)結(jié)構(gòu)(如一個對象自己引用自己),顯然會造成內(nèi)存泄漏。然后就動了對象池的念頭,如果用這種方法,需要很多個對象池,包括虛擬機(jī)運(yùn)行中的表、堆棧里的各種數(shù)據(jù)類型的對象,這么多個對象池看著很礙眼,于是還是決定實現(xiàn)垃圾收集器。

      下面介紹垃圾收集器的工作機(jī)制。內(nèi)存單元并不會在變成垃圾的同時就立刻被回收,而是保持不可到達(dá)的狀態(tài),直到內(nèi)存被耗盡或者內(nèi)存分配達(dá)到某個閾值,用戶程序會被掛起,此時才進(jìn)行垃圾收集,也就是先標(biāo)記正在使用的內(nèi)存,再清除垃圾,即內(nèi)存回收。垃圾收集器回收足夠的內(nèi)存后,用戶程序就可以繼續(xù)工作。如國無法恢復(fù)足夠多的內(nèi)存,則拋出異常。

1. 標(biāo)記

      標(biāo)記是為了識別垃圾,依靠對所有存活對象進(jìn)行一次全局遍歷來確定哪些內(nèi)存可以回收。這個遍歷從根出發(fā)(運(yùn)行時的棧和表),利用相互引用關(guān)系,標(biāo)記所有存活對象,除此之外,其他內(nèi)存就是垃圾。這里強(qiáng)調(diào)下,標(biāo)記并不會沿著已經(jīng)被標(biāo)記的單元追蹤下去,這確保了標(biāo)記能夠終止。

2. 縮并

      用戶程序在堆上分配多種大小不同的對象,經(jīng)過標(biāo)記,我們發(fā)現(xiàn),堆空間變得破碎,如果不擴(kuò)展堆,也許就無法分配一個大型對象,因為找不到一個足夠大的“空洞”容納新的對象 ,即使空閑內(nèi)存的總量是足夠的。還有另外一個問題,經(jīng)過若干個垃圾收集周期后,分配一個小型對象要采用什么算法?首次匹配代價低點(diǎn),但是會產(chǎn)生更多碎片;最佳匹配產(chǎn)生的碎片少了,但是耗費(fèi)的代價高。這顯然提高了內(nèi)存分配的難度。基于以上的討論,對內(nèi)存進(jìn)行縮并就是自然的事了。即把空閑的內(nèi)存掃到一起,也把正在使用的內(nèi)存掃到一起,這樣就把堆空間分成了兩部分。這樣空閑的內(nèi)存連續(xù)了,也就解決了內(nèi)存碎片的問題。當(dāng)為新對象分配內(nèi)存時,再也不用尋找合適的“空洞”,只需把記錄空閑內(nèi)存的基點(diǎn)后移,大大提高了內(nèi)存分配的效率。

3. 分代收集

      我們先有這樣的假設(shè):大多數(shù)對象都在年輕的時候死亡,而越老的對象則越不可能死亡。在垃圾收集的過程中,用戶程序是被掛起的,如果對整個堆都進(jìn)行垃圾收集,顯然用戶程序等待的時間是很長的。如果我們能把工作集中在回收最有可能是垃圾的對象上,就能讓內(nèi)存回收的效率更高,對用戶程序的影響更小。

      基于以上假設(shè),我們需要區(qū)分年輕對象和年老對象。把對象按年齡分到堆中的不同區(qū)域里,其中最年輕的分代會被頻繁地收集,而較老的分代則收集頻率會低得多。對象首先在最年輕的分代里分配,如果它們的壽命足夠長,能夠在足夠多次收集中存活下來(這里就是一次),則會被提升到較老的分代里。這里注意一下,較老的對象可能引用了較年輕的對象,我們?nèi)孕鑼Υ诉M(jìn)行掃描,但是我們現(xiàn)在不必把年老的對象從一個半?yún)^(qū)復(fù)制到另一個半?yún)^(qū)了,將垃圾收集器的努力集中在回收最年輕的分代所占據(jù)的內(nèi)存上,節(jié)省了用戶等待的時間。

posted on 2010-05-14 12:59 Lyt 閱讀(2253) 評論(3)  編輯 收藏 引用 所屬分類: 垃圾收集器

FeedBack:
# re: 稚嫩版垃圾收集器 之 工作機(jī)制
2010-05-14 14:50 | 陳昱(CY)
學(xué)習(xí)了。
內(nèi)存池整理時機(jī)的那個“閾值”弄成動態(tài)的,和“年老的對象”的數(shù)量成比例,效率應(yīng)該比較好,純猜測....  回復(fù)  更多評論
  
# re: 稚嫩版垃圾收集器 之 工作機(jī)制
2010-05-14 15:02 | Lyt
@陳昱(CY)
暫時我只是等到內(nèi)存耗盡了再收集,那個“閾值”跟“年老對象”的數(shù)量成比例具體該怎么折騰心理還沒譜。  回復(fù)  更多評論
  
# re: 稚嫩版垃圾收集器 之 工作機(jī)制
2011-03-17 22:26 | 溪流
路過,學(xué)習(xí)~  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲深夜福利视频| 亚洲欧美日本在线| 欧美国产视频在线观看| 亚洲高清av在线| 模特精品在线| 欧美激情麻豆| a4yy欧美一区二区三区| 一区二区三区免费在线观看| 国产精品户外野外| 久久精品国产清高在天天线 | 影音先锋亚洲电影| 免费日韩一区二区| 欧美精品亚洲一区二区在线播放| 一二三四社区欧美黄| 亚洲一二三四久久| 国内成人精品视频| 亚洲欧洲日韩在线| 国产精品视频| 欧美成人免费在线| 欧美手机在线| 麻豆精品视频在线| 欧美色精品天天在线观看视频| 香蕉av福利精品导航| 久久另类ts人妖一区二区| 日韩一级精品| 欧美专区中文字幕| 一区二区免费看| 久久国产成人| 亚洲视频中文| 久久久噜噜噜| 午夜宅男久久久| 欧美成人午夜影院| 欧美在线啊v| 欧美理论电影在线观看| 久久精彩免费视频| 欧美日韩中文字幕在线| 欧美大色视频| 国产色综合久久| 亚洲精品视频在线播放| 在线国产日韩| 欧美一区午夜视频在线观看| 一二三区精品| 欧美成人四级电影| 美女主播一区| 国产一区999| 亚洲视屏一区| 一级成人国产| 欧美成人免费小视频| 久久午夜电影网| 国产欧美日韩在线播放| 99热免费精品| 一区二区久久久久久| 美女视频黄免费的久久| 久久亚洲国产成人| 国产亚洲第一区| 亚洲一区二区不卡免费| 一本色道久久综合狠狠躁的推荐| 久久视频一区二区| 久久躁狠狠躁夜夜爽| 国产色视频一区| 性色一区二区三区| 久久国产一区二区三区| 国产日韩在线亚洲字幕中文| 一区二区三区久久久| 亚洲天堂成人在线观看| 欧美日韩一级大片网址| 日韩一区二区精品葵司在线| 亚洲精品乱码久久久久久按摩观| 久久综合99re88久久爱| 欧美a级片网| 亚洲国产精品va在看黑人| 免费国产一区二区| 亚洲国语精品自产拍在线观看| 亚洲三级毛片| 欧美日韩成人在线视频| 一区二区三区国产精品| 午夜精品理论片| 国产一区二区三区电影在线观看| 欧美一区高清| 欧美高清在线一区| 日韩香蕉视频| 国产精品一二| 久久九九热免费视频| 男人的天堂亚洲在线| 亚洲欧洲三级电影| 欧美无乱码久久久免费午夜一区| 一区二区三区国产精品| 久久都是精品| 亚洲韩国青草视频| 欧美午夜一区| 久久九九99| 亚洲精品国产欧美| 欧美在线免费播放| 亚洲国产精品久久久久婷婷884 | 欧美怡红院视频| 久久嫩草精品久久久久| 日韩天堂av| 欧美日韩亚洲国产精品| 亚洲欧美综合国产精品一区| 欧美成人免费播放| 亚洲欧美制服另类日韩| 在线不卡亚洲| 欧美性淫爽ww久久久久无| 欧美一区免费视频| 亚洲久久成人| 欧美成人午夜激情| 欧美亚洲一区在线| 亚洲精品一区二区三区av| 国产日韩欧美中文| 欧美精彩视频一区二区三区| 先锋亚洲精品| 日韩一区二区精品葵司在线| 久久久久免费观看| 亚洲欧美精品在线观看| 亚洲国产欧美一区二区三区久久| 国产精品xvideos88| 免费精品视频| 久久精品国产99| 亚洲欧美成人网| 亚洲乱码视频| 亚洲国产精品久久久久婷婷老年| 欧美一区二区免费观在线| 一区二区三区免费观看| 亚洲国产精品欧美一二99| 国内精品免费在线观看| 欧美视频在线播放| 欧美人与禽性xxxxx杂性| 久久综合伊人77777| 欧美一级艳片视频免费观看| 亚洲视频综合| 在线一区免费观看| 夜夜爽夜夜爽精品视频| 亚洲精品一区在线| 亚洲国产精品成人va在线观看| 美女视频黄 久久| 久久免费视频在线| 久久亚洲综合色一区二区三区| 欧美制服丝袜第一页| 午夜欧美大片免费观看| 亚洲综合久久久久| 亚洲一区一卡| 亚洲欧美在线视频观看| 亚洲自拍另类| 午夜精品视频| 久久精品日产第一区二区| 久久福利资源站| 久久久久久日产精品| 蜜桃av一区二区| 欧美电影电视剧在线观看| 欧美激情乱人伦| 亚洲精品九九| 在线亚洲伦理| 欧美一级播放| 久久综合给合久久狠狠色| 免费日韩成人| 欧美jizzhd精品欧美巨大免费| 免费高清在线一区| 欧美乱妇高清无乱码| 欧美性猛交99久久久久99按摩| 国产精品久久久久91| 国产午夜精品一区二区三区视频 | 午夜精品久久99蜜桃的功能介绍| 亚洲手机在线| 久久高清免费观看| 免费永久网站黄欧美| 亚洲日韩第九十九页| 亚洲午夜免费视频| 久久久91精品国产| 欧美激情一区二区三区蜜桃视频| 欧美日韩在线视频一区| 国产欧美日韩精品a在线观看| 黄色在线一区| 99热在这里有精品免费| 香蕉久久夜色精品国产使用方法| 久久九九精品99国产精品| 亚洲国产欧美不卡在线观看| 在线天堂一区av电影| 久久视频在线视频| 欧美性猛交99久久久久99按摩 | 欧美成人精品福利| 欧美特黄一级大片| 在线精品在线| 亚洲欧美日韩在线观看a三区| 久久亚洲精品一区二区| av成人激情| 欧美mv日韩mv国产网站| 国产精品一区二区在线| 亚洲精品美女91| 久久大逼视频| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 久久aⅴ国产欧美74aaa| 欧美日韩成人一区二区| 狠狠88综合久久久久综合网| 一区二区毛片| 亚洲丰满在线| 久久精品一区二区三区中文字幕| 欧美日韩一区高清| 亚洲精选在线观看| 蜜桃av综合| 欧美在线视频一区二区三区|