• <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>
            隨筆 - 119  文章 - 290  trackbacks - 0

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

            常用鏈接

            留言簿(12)

            隨筆分類

            我的博客

            搜索

            •  

            積分與排名

            • 積分 - 305321
            • 排名 - 84

            最新評論

            閱讀排行榜

            昨天已經(jīng)通過gc_enterstack_push的實現(xiàn),了解到用一個近似調(diào)用堆棧的東西,保存每一級調(diào)用中分配的自由內(nèi)存的id。
            今天看看gc_leave。gc_leave有一個可變參數(shù)列表,這些參數(shù)的用途是,將本函數(shù)分配的自由內(nèi)存的聲明周期再保留更長一點的時間。
            看看實現(xiàn)就知道了:

             1void
             2gc_leave(void *p,)
             3{
             4    void **head;
             5    if (E.stack.current >= E.stack.bottom) {
             6        E.stack.top = E.stack.current;
             7        E.stack.current -= E.stack.data[E.stack.current].number;
             8    }

             9    else {
            10        int parent,child;
            11        --E.stack.bottom;
            12        parent=E.stack.data[E.stack.bottom-1].stack;
            13        child=E.stack.data[E.stack.bottom].stack;
            14        node_add(parent, child | UNSET_MASK);
            15        node_free(child);
            16        E.stack.current=E.stack.bottom-1;
            17        E.stack.top = E.stack.current + 1;
            18    }

            19
            20    head=&p;
            21
            22    while (*head) {
            23        stack_push(map_id(*head));
            24        ++head;
            25    }

            26}

            我們知道,調(diào)用gc_leave,也就意味著要離開當前的函數(shù)回到父函數(shù)上了,那么堆棧也要退回到父函數(shù)調(diào)用gc_enter后的情形。
            首先看if部分,因為在 E.stack.current的位置上保存的是父函數(shù)中分配的自由內(nèi)存的數(shù)量,所以第6行讓top指向這里,第7行用current對這個數(shù)量做一個減法,就變成了父函數(shù)堆棧的情形了。

            不過9行else部分比較令人困惑。僅僅在第一次調(diào)用gc_enter之前,current會小于bottom,此時current=0,bottom=1。那么接下來的第11行執(zhí)行后bottom=0,第12行看起來就會訪問索引為-1處的數(shù)據(jù)。我還沒有跑過這個庫,也沒有在源碼中搜索出 E.stack.bottom比較特殊的賦值操作,所以不太確定到底是怎么回事。所以,這個先暫時放下,等以后看到其他內(nèi)容,或者跑一下這個庫的時候,再搞清楚這段代碼的意義。

            最后是一個while循環(huán),處理可變參數(shù)列表,這些參數(shù)是需要延長生命的自由內(nèi)存指針。怎么做呢?因為現(xiàn)在已經(jīng)回到了父函數(shù)的gc堆棧上,所以就把這些需要延長生命的自由內(nèi)存壓入父函數(shù)的gc堆棧即可,見23行。
            不過這也意味著,他們的生命最少只延長到父函數(shù)也退出而已。

            OK,看完了分配出來的內(nèi)存的兩種管理方式,明天終于可以看看如何進行內(nèi)存回收了。
            posted on 2008-09-18 20:00 LOGOS 閱讀(1945) 評論(2)  編輯 收藏 引用

            FeedBack:
            # re: 垃圾收集的那點事(H)[未登錄] 2008-09-20 12:45 好東西
            特來支持一下,繼續(xù)努力。  回復  更多評論
              
            # re: 垃圾收集的那點事(H) 2013-12-30 17:11 7Qing_
            非常感謝  回復  更多評論
              
            精品久久久久久无码免费| 久久久久亚洲精品中文字幕| 亚洲国产一成人久久精品| 亚洲中文精品久久久久久不卡| 看久久久久久a级毛片| 久久精品人成免费| 久久久久一本毛久久久| 伊人久久大香线蕉亚洲| 久久国产视频99电影| 亚洲精品乱码久久久久久自慰| 欧美一区二区精品久久| 久久国产欧美日韩精品免费| 久久丫精品国产亚洲av| 久久久久国产一级毛片高清板| 狠狠综合久久综合88亚洲| 日本久久久久久中文字幕| 伊人久久大香线蕉无码麻豆| 久久99精品久久久久久秒播| 国产精品99久久久精品无码| 久久亚洲国产中v天仙www| 国产成人精品综合久久久| 中文字幕亚洲综合久久| 精品国产一区二区三区久久久狼| 久久久久亚洲精品中文字幕| 亚洲国产精品久久久久| 久久久久久国产精品无码超碰 | 亚洲色欲久久久久综合网| 久久亚洲国产中v天仙www| 久久婷婷五月综合国产尤物app| 人妻中文久久久久| 久久久人妻精品无码一区 | 久久精品中文字幕大胸| 久久久久久久亚洲精品| 97精品伊人久久久大香线蕉 | 天天躁日日躁狠狠久久 | 国产精品欧美久久久久无广告 | 青青青国产精品国产精品久久久久 | 久久综合亚洲色HEZYO国产| 国产福利电影一区二区三区,免费久久久久久久精 | 激情久久久久久久久久| 国产成年无码久久久久毛片|