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

隨筆 - 119  文章 - 290  trackbacks - 0

博客搬家了哦,請移步
叫我abc

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 306391
  • 排名 - 84

最新評論

閱讀排行榜

終于可以看看這個gc庫是如何收集垃圾內(nèi)存的了。還是老方法,先貼代碼,來一個直觀上的認(rèn)識

 1void
 2gc_collect()
 3{
 4    int i;
 5    stack_pack();
 6    cache_flush();
 7    gc_mark(0);
 8    for (i=0;i<E.size;i++{}
 9    E.mark+=2;
10}
首先是stack_pack,這將是要研究的第一個子函數(shù)。根據(jù)其名字,可以推測會操作前面看過的管理自由內(nèi)存的堆棧,事實(shí)上也是如此。該函數(shù)將清理堆棧,將暫時不能釋放的自由內(nèi)存用一種自動化的方式標(biāo)記出來,這種方式就是為他們建立依賴關(guān)系。建立依賴關(guān)系也是內(nèi)存不能被當(dāng)作垃圾的唯一理由。
下一步是cache_flush,這個以前已經(jīng)看過,將cache的依賴關(guān)系寫入到實(shí)際管理的容器上。
第三步是gc_mark,用來給所有有依賴關(guān)系的內(nèi)存做一下標(biāo)記,證明他們不是垃圾。
第四步是一個for循環(huán),循環(huán)體太長暫時先不貼出來,不過其工作就是將標(biāo)記不合格的內(nèi)存釋放,因?yàn)樗麄兪抢鴥?nèi)存。
最后更新標(biāo)記,標(biāo)記是一個遞增的整數(shù)。

垃圾收集的過程直觀上就是這樣,現(xiàn)在就來逐步細(xì)看,先看看stack_pack。聲明一點(diǎn),通過這個函數(shù),可以解開之前在gc_leave中為何會有E.bottom大于 E.current的緣故(除了初始化)。
1static void
2stack_pack()
3{
4    int bottom=stack_pack_internal(E.stack.bottom,E.stack.current,E.stack.top);
5    E.stack.top=E.stack.bottom=bottom;
6    E.stack.current=bottom-1;
7}
stack_pack的代碼很少,因此可以斷定關(guān)鍵的地方都在stack_pack_internal上了,其返回值bottom也有重要意義。
第5、6行,直接將top,bottom,current指針重置到一個類似于初始化的狀態(tài),不過此時的bottom通常都已經(jīng)往上移動了,而current小于bottom。
也就是說,每次調(diào)用gc_collect后,總會造成current小于bottom的結(jié)果,那么gc_leave的實(shí)現(xiàn)里有對這種判斷的處理也就不奇怪了,不過具體這種處理是何用意,看了stack_pack_internal之后再說。

 1static int
 2stack_pack_internal(int from,int to,int top)
 3{
 4    if (to < from) {
 5        int parent = E.stack.data[to].stack;
 6        while (from < top) {
 7            node_add(parent,E.stack.data[from].handle);
 8            ++from;
 9        }

10        return to+1;
11    }

12    else {
13        int bottom=stack_pack_internal(from,to-E.stack.data[to].number,to);
14        int node=node_alloc(0);
15        ++to;
16        while (to<top) {
17            node_add(node,E.stack.data[to].handle);
18            ++to;
19        }

20        node_add(E.stack.data[bottom-1].stack,node);
21        E.stack.data[bottom].stack=node;
22        return bottom+1;
23    }

24}

快速掃一眼stack_pack_internal,發(fā)現(xiàn)他是一個遞歸函數(shù),其次確認(rèn)一下三個參數(shù),分別對應(yīng)bottom,current,top,也就是當(dāng)前函數(shù)下的堆棧指針位置。
第4行的代碼可以看成 if ( current < bottom ),通過以前看過的代碼,可以了解到以下3點(diǎn):
1.初始化之后,current < bottom
2.調(diào)用gc_collect之后,current < bottom
3.調(diào)用了gc_enter后,current 絕對不會小于bottom
因此else部分的代碼才是要先考慮的代碼,也就是遞歸的部分。

第13行的代碼可以寫成
bottom = stack_pack_internal( bottom , current - E.stack.data[ current ].number , current )
有看出什么來嗎?比如說從number,或者是從這個減法。沒錯喲,這三個用于遞歸的參數(shù),其實(shí)是在父函數(shù)環(huán)境下的堆棧指針位置。也就是說,stack_pack_internal遞歸的調(diào)用,由于執(zhí)行常規(guī)的else部分的代碼,因此不斷的傳遞父函數(shù)的堆棧指針位置,不斷的尋根,不斷的追宗認(rèn)祖,最終就會回到stack剛初始化的狀態(tài),此時 current < bottom。很酷的,現(xiàn)在不得不暫時放下else部分,來看看if部分,這if部分可就只是為了這么一下而準(zhǔn)備的。
第5行,取的是current節(jié)點(diǎn)處的值。剛初始化的stack,這里存放著全局內(nèi)存之根,最大的所有者。
接下來,由于此時bottom 等于 top,所以while循環(huán)暫不執(zhí)行,直接返回bottom。現(xiàn)在可以回到else部分了。

第14行,從 E.pool中分配了一個節(jié)點(diǎn),當(dāng)然該節(jié)點(diǎn)實(shí)際沒有維護(hù)任何內(nèi)存,不過這個節(jié)點(diǎn)可有大用處。
第16到第19行,這個while循環(huán)內(nèi),將某一級函數(shù)(遞歸太多,是哪一級已經(jīng)不重要了)中分配出來的自由內(nèi)存和剛申請的node建立依賴關(guān)系,這級函數(shù)的自由內(nèi)存id可都記錄在current+1到top之間的handler中呢(current記錄父函數(shù)分配的自由內(nèi)存數(shù)量)。
第20行,將剛申請node和 E.stack.data[ bottom -1 ].stack建立以來關(guān)系,不過這到底是什么呢?如果bottom-1等于0的話,那就是node和全局建立依賴關(guān)系,否則,看起來就像是和父函數(shù)建立了依賴關(guān)系。第21行驗(yàn)證了這個想法,這一賦值,將node記錄到了堆棧中。就此也知道了stack成員變量的作用,表示某個函數(shù)的節(jié)點(diǎn)。
最后返回bottom+1,即bottom指針移動了,而bottom-1必然指向了代表父函數(shù)的node。

以上的分析看其來都比較混亂,不過從整體想像的話:
假設(shè)函數(shù)其實(shí)是一種對象,他引用著那些在他函數(shù)體內(nèi)分配出來的自由內(nèi)存,因此他和那些內(nèi)存就有依賴關(guān)系。從最上層的函數(shù)開始,建立表示該函數(shù)對象的節(jié)點(diǎn),和所有在這一級函數(shù)中分配的自由內(nèi)存建立依賴關(guān)系。然后到下一級子函數(shù),也建立一個表示該函數(shù)對象的節(jié)點(diǎn),和所有在這一級函數(shù)中分配的自由內(nèi)存建立依賴關(guān)系。如此遞歸,直到調(diào)用了gc_collect的這一級函數(shù)為止。
管理自由內(nèi)存的堆棧,經(jīng)過這樣處理后,里面就剩下了每一級函數(shù)對象的節(jié)點(diǎn)id,一個個的緊挨著。而作為到調(diào)用gc_collect為止,這一路下來分配的自由內(nèi)存,都是暫時不能釋放的,已經(jīng)建立依賴關(guān)系放進(jìn)了 E.cache。

根據(jù)stack_pack后兩行的代碼,就可以判斷出if代碼中while循環(huán)是用來干什么吃的了:同一級函數(shù)中,在gc_collect后,繼續(xù)分配自由內(nèi)存,然后再gc_collect的話,就會執(zhí)行到該while循環(huán),本質(zhì)也是用來建立依賴關(guān)系的。


最后說說看gc_leave時無法理解的代碼吧,現(xiàn)在已是真相大白了
 1    else {
 2        int parent,child;
 3        --E.stack.bottom;
 4        parent=E.stack.data[E.stack.bottom-1].stack;
 5        child=E.stack.data[E.stack.bottom].stack;
 6        node_add(parent, child | UNSET_MASK);
 7        node_free(child);
 8        E.stack.current=E.stack.bottom-1;
 9        E.stack.top = E.stack.current + 1;
10    }
這是current小于bottom的情形,已經(jīng)被gc_collect了,此時 E.stack.data[0]到 bottom指針之間應(yīng)該都是每一級函數(shù)的象征節(jié)點(diǎn)。
第4、5行,就是一個父函數(shù)和子函數(shù)的關(guān)系,現(xiàn)在既然已經(jīng)從子函數(shù)中退出了,那么也是時候解放子函數(shù)中分配的自由內(nèi)存的時候了,因此第6行解開了父子函數(shù)的依賴關(guān)系,那子函數(shù)中分配的自由內(nèi)存也相應(yīng)的變成垃圾了。
最后兩行恢復(fù)父函數(shù)的堆棧,我想堆棧的形狀也差不多了,E.stack.data[0]到 bottom指針之間應(yīng)該都是每一級函數(shù)的象征節(jié)點(diǎn)。
posted on 2008-09-21 23:17 LOGOS 閱讀(1693) 評論(3)  編輯 收藏 引用

FeedBack:
# re: 垃圾收集的那點(diǎn)事(I) 2008-09-22 11:38 來支持
天天來支持下。
博主有沒有看過一個autofreealloc的玩意?  回復(fù)  更多評論
  
# re: 垃圾收集的那點(diǎn)事(I) 2008-09-22 14:11 LOGOS
@來支持
沒聽說過,搜索了一下,不知道你說的是不是這個
http://blog.csdn.net/xushiweizh/archive/2006/11/19/1396573.aspx

這個autofreealloc的責(zé)任很明確-----理解該垃圾回收器的關(guān)鍵點(diǎn)在于,是在于理解它的目標(biāo):為一個復(fù)雜的局部過程(算法)提供自動內(nèi)存回收的能力。
所以從各種意義上他都比yfgc簡單得多  回復(fù)  更多評論
  
# re: 垃圾收集的那點(diǎn)事(I) 2008-09-22 22:40 來支持
是的。
許這個所謂半自動GC花了一些時間研究過他的實(shí)現(xiàn),感覺應(yīng)用面比較小,而且只適合單線程環(huán)境。爭議也比較大

個人對C/C++下輕量GC實(shí)現(xiàn)非常敢興趣,云風(fēng)這個還沒時間深入去看,現(xiàn)在甚至還不知道它能做什么,不能做什么,在什么環(huán)境下適用,什么環(huán)境下不適用。

提個建議,博主你能不能對云風(fēng)這個GC寫一個綜述性和應(yīng)用實(shí)例的文章,然后再去探討內(nèi)部的實(shí)現(xiàn)機(jī)理。單純的代碼分析好像C++博客的弟兄們都不怎么感冒,這么好的東西都沒人關(guān)注。呵呵。



  回復(fù)  更多評論
  

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              久久精品久久99精品久久| 久久免费视频在线| 国产模特精品视频久久久久 | 亚洲三级视频| 亚洲人成久久| 这里只有精品在线播放| 亚洲图片欧美日产| 亚洲视频专区在线| 欧美一区二区三区四区视频| 欧美一区二区视频97| 久久久噜噜噜久久中文字免| 欧美电影美腿模特1979在线看| 亚洲国产高清在线观看视频| 亚洲激情国产| 亚洲一区二区成人| 久久久91精品国产一区二区三区 | 久久午夜视频| 亚洲国产另类精品专区| 中文精品视频| 久久亚洲精品伦理| 欧美三级视频| 在线观看亚洲精品视频| 一本色道**综合亚洲精品蜜桃冫| 性欧美1819sex性高清| 蜜臀久久99精品久久久久久9| 亚洲高清视频一区| 午夜精品视频一区| 欧美—级在线免费片| 国产日韩在线不卡| 亚洲欧洲偷拍精品| 久久精品女人天堂| 亚洲精品一区二区三区福利| 午夜精品久久久久久久| 欧美激情综合五月色丁香| 国产综合香蕉五月婷在线| 一区二区日韩免费看| 美乳少妇欧美精品| 亚洲欧美国产日韩中文字幕| 欧美精品福利在线| 亚洲国产欧美国产综合一区| 久久久亚洲一区| 亚洲欧美国产不卡| 国产精品久久久久9999高清| 一区二区欧美激情| 亚洲电影自拍| 欧美在线视频免费| 99一区二区| 欧美剧在线观看| 亚洲精品1区2区| 欧美激情精品久久久久久久变态| 久久av一区二区| 国产一区二区三区丝袜| 香蕉av777xxx色综合一区| 一级日韩一区在线观看| 欧美日韩亚洲国产一区| 夜久久久久久| 亚洲精品视频免费| 欧美伦理91i| 一区二区av| 日韩一级片网址| 欧美三区在线视频| 99riav1国产精品视频| 欧美激情性爽国产精品17p| 久久久噜噜噜久久人人看| 欧美一区二区三区四区在线观看地址| 免费成人黄色av| 国产日韩在线看片| 亚洲在线电影| 欧美国产免费| 久久一区二区三区国产精品| 国产视频精品xxxx| 午夜老司机精品| 亚洲视频999| 欧美日韩亚洲高清一区二区| 亚洲精品网址在线观看| 欧美91视频| 欧美区日韩区| 亚洲视频免费在线观看| 亚洲人成久久| 欧美人与禽猛交乱配| 99国产精品自拍| 亚洲毛片网站| 国产精品v亚洲精品v日韩精品| 一级成人国产| 亚洲男女自偷自拍| 欧美在线资源| 在线国产精品一区| 亚洲高清二区| 欧美精品三区| 一区二区三区免费观看| 亚洲精品视频在线播放| 欧美日韩一区二区三区四区五区| 在线一区二区三区四区五区| 欧美成人精品激情在线观看| 欧美午夜精品久久久久久浪潮| 亚洲伊人第一页| 亚洲午夜av在线| 国产日韩1区| 久久综合图片| 欧美国产日韩一区二区| 在线综合亚洲欧美在线视频| 亚洲一区二区免费视频| 欧美日韩午夜| 亚洲综合色婷婷| 久久成人在线| 欧美成人首页| 免费不卡在线观看av| 美女被久久久| 中文有码久久| 欧美不卡视频| 亚洲一区精品视频| 欧美激情一二区| 欧美一区二区三区电影在线观看| 久久精品二区三区| 一区二区日韩免费看| 欧美资源在线观看| 妖精视频成人观看www| 欧美影视一区| 欧美在线网址| 欧美人成免费网站| 久久精品九九| 欧美日韩一区不卡| 美国十次成人| 欧美性猛片xxxx免费看久爱| 久久先锋资源| 国产精品久久7| 亚洲国产一区二区三区a毛片| 国产免费成人av| 亚洲欧洲精品一区二区三区 | 亚洲第一偷拍| 亚洲午夜精品久久久久久浪潮| 伊人久久成人| 在线视频欧美一区| 亚洲激情视频网站| 久久国产精品一区二区| 亚洲一二三区在线观看| 美女视频黄a大片欧美| 久久精品五月| 国产精品少妇自拍| 夜夜爽99久久国产综合精品女不卡| 国产精品日日摸夜夜摸av| 亚洲丰满少妇videoshd| 激情久久一区| 亚洲综合国产| 日韩视频在线观看国产| 亚洲人成网站777色婷婷| 在线成人黄色| 久久精品国产视频| 午夜日韩av| 噜噜噜在线观看免费视频日韩| 久久久视频精品| 亚洲日本va在线观看| 久久精品首页| 久久综合五月天婷婷伊人| 国产日韩欧美成人| 亚洲一区二区成人| 午夜精品久久久久久99热| 久久一区国产| 99综合精品| 亚洲视频在线观看网站| 国产精品成人免费视频| 99亚洲一区二区| 亚洲一区二区四区| 国产精品久久久久aaaa樱花 | 国产精品视频精品视频| 性色av一区二区三区| 欧美中文字幕视频| 国内精品视频一区| 久久久久九九视频| 亚洲精品午夜精品| 欧美性一二三区| 在线性视频日韩欧美| 久久久99久久精品女同性| 国产日韩一区| 午夜精品一区二区三区在线视 | 中文亚洲欧美| 亚洲精品一区二区三区在线观看| 欧美午夜精品久久久久久久| 亚洲午夜女主播在线直播| 亚洲欧美中文日韩在线| 国产精品影音先锋| 久久精品国产一区二区三| 欧美福利一区二区| 亚洲影视在线播放| 欧美成人午夜免费视在线看片| 亚洲网友自拍| 美女露胸一区二区三区| 日韩一区二区福利| 国产欧美另类| 欧美国产高潮xxxx1819| 亚洲综合电影| 夜夜嗨一区二区三区| 久久午夜电影网| 99在线精品视频在线观看| 国产目拍亚洲精品99久久精品| 久久婷婷综合激情| 亚洲少妇一区| 久久亚洲欧美| 亚洲一区二区三区精品在线观看 | 亚洲视频一区在线|