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

隨筆 - 119  文章 - 290  trackbacks - 0

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

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 306391
  • 排名 - 84

最新評論

閱讀排行榜

cache_flush算是這個庫最糟糕的一段代碼了,總共有100多行,縮進糟糕,做很多不同的工作。我就納悶,為什么不抽些子函數出來,這樣的代碼基本上不具備維護價值,因為自己重寫一次,比搞明白這個函數有趣多了。
由于這個函數實在太長,所以不一次全貼上來,一部分一部分的看吧。

qsort(E.cache,CACHE_SIZE,sizeof(struct cache_node),cache_node_cmp);

//----------------------------------------
static int
cache_node_cmp(
const void *a,const void *b)
{
    
const struct cache_node *ca=(const struct cache_node *)a;
    
const struct cache_node *cb=(const struct cache_node *)b;
    
if (ca->parent != cb->parent) {
        
return cb->parent - ca->parent;
    }

    
if (ca->parent == -1 ) {
        
return 0;
    }

    
return (ca->child & ~ UNSET_MASK) - (cb->child & ~UNSET_MASK);
}
首先,對 E.cache進行排序,比較子是cache_node_cmp。
return cb->parent - ca->parent ,是用 cb減去ca的,因此首先根據parent_id進行降序排序。注意,在這一比較結果中,如果ca->parent = -1,那么比較結果為正,空閑節點ca往數組右邊移動;如果cb->parent = -1,那么比較結果為負,空閑節點cb還是會處在數組右邊。
為什么要注意這個呢?因為本次排序的一個結果就是,那些空閑節點都集中到了cache數組的右邊,只要遍歷cache的過程中遇到了第一個空閑節點,那么剩下的必然都是空閑節點了。
當然要達成這個排序結果,還需要下面的這步,if (ca->parent == -1 ) {return 0;}
比較子的最后一句,在parent_id相同的情況下,按child_id升序排序。

E.cache經過排序后,呈現出以下狀況:
1.根據parent_id呈降序排序,并且parent_id相同的節點緊挨在一起
2.空閑的cache節點全部都排在了數組的右邊
3.parent_id相同的節點,按child_id升序排序

    while (i<CACHE_SIZE) {

        
if (parent==-1{
            
return;
        }
排序之后,就是遍歷有序的cache數組。可以看到排序的效果了,當parent_id = -1的時候,就只剩下空閑的cache_node,因此可以退出遍歷。

        head=&E.cache[i];
        next
=head;
        sz
=0;

        
while (next->parent == parent && i<CACHE_SIZE) {
            sz 
+= 1 - UNSET_MASK_BIT(next->child);
            
++next;
            
++i;
        }
這一段代碼,是統計同一parent_id下child的數目。因為有些child_id被標記了 UNSET_MASK,因此這種cache節點就不用統計到總數中了。其中UNSET_MASK_BIT是位移操作,如果child被標記了UNSET_MASK,那么位移的結果就是1,1-1=0,也就沒有統計到總數中了。

struct node *node=&E.pool[parent];
children
=node->u.n.children;
統計了parent擁有的child之后,接下來就是要把這些child記錄到parent的數據結構上了。這里不得不回顧一下struct node的定義,上次看的時候,并沒有探討struct link *children是做什么的,現在可以看看link的定義
struct link {
    
int number;
    
int children[1];
}
;
這個結構就是parent用來記錄其所有child_id的地方。其中number用來記錄child的總數量,而children則是一個整數數組,用來記錄所有的child_id。
cache_flush剩下的操作,就是把新的child_id添加到children中去,當然其中包含其他一些細節處理。這里先把這些東西交代清楚,因為其后的代碼將是比較難以理解的,我仍不是十分的明白。
posted on 2008-09-15 21:34 LOGOS 閱讀(2157) 評論(1)  編輯 收藏 引用

FeedBack:
# re: 垃圾收集的那點事(E) 2008-09-16 10:04 zuhd
寫的不錯,云風這段代碼是用c實現的,讀起來確實有點晦澀,作者分析的精神很贊!  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
              国产精品美女一区二区在线观看| 亚洲永久精品国产| 一本一本久久a久久精品牛牛影视| 国产精品美女一区二区在线观看 | 亚洲欧美卡通另类91av | 国产精品一区二区黑丝| 国产精品嫩草99av在线| 国产精品久久午夜夜伦鲁鲁| 国产精品久久国产精品99gif| 国产精品久久久久三级| 国产综合久久久久久鬼色| 亚洲电影欧美电影有声小说| 亚洲毛片在线观看| 亚洲欧美日韩在线观看a三区| 久久本道综合色狠狠五月| 美女网站久久| 亚洲色图自拍| 免费久久99精品国产自| 欧美精品日韩精品| 国产老女人精品毛片久久| 国产在线视频欧美| 99re热这里只有精品视频| 亚洲天堂av图片| 美国十次了思思久久精品导航| 日韩视频一区二区| 久久琪琪电影院| 欧美午夜精品久久久久久孕妇 | 亚洲伦理中文字幕| 亚洲三级视频| 欧美午夜视频在线| 韩日精品视频| 亚洲欧美综合v| 亚洲成色最大综合在线| 亚洲成色精品| 久久精品理论片| 国产精品高清一区二区三区| 国产一区二区三区黄| 一区二区三区国产精华| 久久综合色播五月| 亚洲综合成人在线| 国产精品福利在线观看网址| 亚洲黄色尤物视频| 欧美高清视频www夜色资源网| 欧美一区二区三区视频免费| 国产精品久久久久久久久久尿| 最新国产の精品合集bt伙计| 久久久久久久久蜜桃| 亚洲伊人一本大道中文字幕| 欧美极品aⅴ影院| 亚洲三级观看| 亚洲盗摄视频| 欧美成年人网站| 亚洲日本中文| 亚洲精品久久久久| 欧美日韩一区二区三区四区在线观看| 亚洲第一天堂av| 久久尤物视频| 久久综合狠狠| 樱桃成人精品视频在线播放| 久久精品国产亚洲精品| 亚洲少妇一区| 国产综合精品| 欧美电影免费网站| 欧美黄污视频| 亚洲一区二区三区国产| 亚洲视频一二三| 国产精品尤物| 久久免费精品视频| 男人的天堂亚洲| 在线视频日本亚洲性| 一区二区三区四区国产精品| 欧美日韩中文在线| 亚洲欧美成人一区二区在线电影| 亚洲综合电影一区二区三区| 国产精品视频一区二区三区| 久久精品一区二区| 男男成人高潮片免费网站| 一本色道久久综合| 亚洲影院免费观看| 狠狠色综合一区二区| 欧美高清不卡| 国产精品国产一区二区| 久久综合一区二区| 欧美超级免费视 在线| 午夜欧美精品久久久久久久| 久久精品视频免费播放| 日韩一级裸体免费视频| 亚洲一区二区三区中文字幕在线 | 亚洲一区二区三区免费视频| 亚洲精品国产精品乱码不99按摩 | 亚洲伊人伊色伊影伊综合网| 国产乱人伦精品一区二区| 久久精品亚洲一区| 欧美精选在线| 欧美在线精品一区| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产区精品视频| 美女黄毛**国产精品啪啪| 欧美激情精品久久久| 亚洲一卡久久| 裸体素人女欧美日韩| 午夜激情亚洲| 欧美激情综合亚洲一二区| 欧美一区二区大片| 欧美精品在欧美一区二区少妇| 性娇小13――14欧美| 欧美91视频| 久久激情视频免费观看| 欧美日韩国产小视频在线观看| 久久久国产精品一区二区三区| 欧美日韩国产黄| 欧美黄色网络| 亚洲二区在线| 久久se精品一区二区| 亚洲天堂久久| 欧美搞黄网站| 欧美国产第二页| 激情另类综合| 久久久精品久久久久| 欧美一级理论性理论a| 欧美日韩国产首页| 亚洲精品美女在线观看| 在线播放一区| 亚洲愉拍自拍另类高清精品| 99精品欧美| 欧美久久电影| 亚洲精品国产精品久久清纯直播 | 久久久久国内| 久久精品成人一区二区三区| 国产精品久久久久7777婷婷| 亚洲高清视频一区二区| 亚洲黄色av一区| 免播放器亚洲| 亚洲成色精品| 欧美激情一区二区久久久| 在线中文字幕一区| 欧美国产激情| 亚洲精品欧美日韩专区| 日韩性生活视频| 欧美精品福利视频| 夜夜嗨av色综合久久久综合网| 在线一区欧美| 国产精品一区二区三区四区五区| 亚洲视频一区二区| 欧美影院成人| 在线播放日韩| 欧美精品三区| 日韩亚洲一区在线播放| 亚洲一区二区在线看| 国产精品麻豆成人av电影艾秋| 亚洲天堂免费观看| 久久久久国产精品www| 国产一区二区三区黄视频| 久久久久久久999| 欧美国产激情二区三区| 亚洲精品乱码久久久久久按摩观| 美腿丝袜亚洲色图| 99riav久久精品riav| 亚洲欧美激情视频在线观看一区二区三区 | 一区二区三区鲁丝不卡| 亚洲综合视频网| 国产一区二区三区精品久久久| 久久久久久久一区二区| 亚洲国产人成综合网站| 亚洲小说欧美另类婷婷| 国产亚洲一区二区在线观看 | 一本色道久久| 国产精品一区在线观看| 久久精品九九| 一本一本a久久| 久久亚洲私人国产精品va| 亚洲国产女人aaa毛片在线| 欧美日韩精品一区二区三区四区| 亚洲一区二区三区四区五区午夜| 久久久久久久久岛国免费| 亚洲人午夜精品免费| 国产精品magnet| 麻豆精品在线视频| 亚洲一区二区三区视频播放| 欧美成人精精品一区二区频| 一区二区欧美亚洲| 国产一区日韩一区| 欧美日韩黄色大片| 久久精品一本| 亚洲午夜极品| 欧美1级日本1级| 欧美在线free| 亚洲性人人天天夜夜摸| 在线观看免费视频综合| 国产精品久久久爽爽爽麻豆色哟哟| 欧美在线免费| 亚洲私人黄色宅男| 亚洲人成久久| 欧美成人自拍| 女女同性精品视频| 久久精品久久99精品久久| 亚洲欧美日韩久久精品| 这里只有视频精品| 99伊人成综合| 一区二区三区欧美|