• <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>
            Lyt
            posts - 16,comments - 61,trackbacks - 0

                  開發這個垃圾收集器的是為了降低用戶使用語言的難度,回避掉內存使用的囧事(比如內存泄漏)。垃圾收集器工作時,需要掛起用戶程序,等待釋放出不占用的資源后才可繼續工作。如何提高垃圾收集器的性能顯得非常重要。

            1. 垃圾收集器什么時候工作比較合適

                  垃圾收集器會在內存耗盡或內存分配達到某個閾值時才進行工作。內存耗盡要進行垃圾收集是自然的,但是這個閾值到底該多大才合適呢?太小會造成垃圾收集頻率太高,太大會造成內存利用率降低。這里我只是簡單地無視這個問題,等到內存耗盡再進行回收。

            2. 多少個分代才合適

                  垃圾收集器一個工作周期時長極大地依賴于一次收集中存活下來的數據。分代越小,時間越短,然而,一個較小的分代會比較大的分代更容易填滿,從而增大了收集的頻率,除非我們更早地提升對象。但是,分代收集是希望盡可能多的對象中年輕的時候死亡,所以對象不應該被過早地提升。這里我只是簡單地抄襲了.NET,分成三代。

            3. 分代的大小是固定的

                  Generation的大小如果能隨著內存使用情況來改變就好了,不知道要根據啥規律來折騰,心理沒譜。

            4. 一剛開始垃圾收集器申請的內存也是固定大小的

                  如果內存耗盡,垃圾收集后仍然無法提供足夠的內存分配給對象,此時我就只能拋出異常了。有在考慮說,是不是要擴大這個內存,重新申請,重新分配Generation,到底要根據啥規律比較合適暫時還沒明白。

            5. 什么時候提升對象

                  一個對象什么時候提升依賴于這個對象必須在多少次收集中幸存下來。這里我只是簡單地在每次收集后就提升所有的對象,即使某些提升的對象實際上很年輕,會使得年輕對象沒有死亡機會。

             

                  到這里關于垃圾收集器的討論就告一段落了,歡迎大家來噴~

            posted on 2010-05-14 16:34 Lyt 閱讀(1861) 評論(2)  編輯 收藏 引用 所屬分類: 垃圾收集器

            FeedBack:
            # re: 稚嫩版垃圾收集器 之 未解決的問題
            2010-05-14 18:09 | 陳昱(CY)
            如果SmallObject最大大小并不是很大的話~~也許可以根據對象大小弄成多個SmallObjectHeap。

            比如對象大小是2,就放在SmallObjectHeap2,
            對象大小是4,就放在SmallObjectHeap4,
            對象大小是8,就放在SmallObjectHeap8.......

            這樣就可以省去內存縮并的工作。只有當Heap不夠大時,才擴大內存。

            不用執行碎片的方法(參考python的實現):
            struct BlockN
            {
            BlockN* m_Free;
            char data[N];//大小為N的對象數據
            };
            class SmallObjectHeapN
            {
            BlockN m_Blocks[size];
            BlockN* m_NextFree;
            };
            SmallObjectHeapN的類里面有一個指向空閑地址的指針m_NextFree,每個BlockN也有一個指向空閑地址的指針m_Free(初始化成0),
            在一開始的時候SmallObjectHeapN的m_NextFree肯定指向m_Blocks的地址;
            添加的時候,發現m_NextFree所在的block里面的m_Free是0,于是++m_NextFree;
            某個block刪除的時候,m_Free=m_NextFree,而m_NextFree指向這個被刪除的block;
            再次添加對象時,發現m_NextFree指向的block里面的m_Free不是0,則添加完成后,m_NextFree=block->m_Free就行了。  回復  更多評論
              
            # re: 稚嫩版垃圾收集器 之 未解決的問題
            2010-05-14 22:03 | Lyt
            @陳昱(CY)
            看懂,我在實現對象池的時候就是用類似的算法。  回復  更多評論
              
            人妻无码αv中文字幕久久| 国产亚洲美女精品久久久2020| 日本久久久久久中文字幕| 精品久久久久国产免费| 久久精品国产亚洲AV忘忧草18 | 日韩精品久久无码中文字幕| 粉嫩小泬无遮挡久久久久久| 欧美久久天天综合香蕉伊| 久久99精品久久久久婷婷| 久久丝袜精品中文字幕| 丁香五月网久久综合| 久久99精品国产麻豆宅宅| 久久久久久av无码免费看大片| 日产精品久久久一区二区| 久久影院亚洲一区| 国产精品青草久久久久福利99| 亚洲乱码中文字幕久久孕妇黑人| 久久成人18免费网站| 亚洲午夜精品久久久久久人妖| 中文字幕乱码久久午夜| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 国产高清国内精品福利99久久| 无码人妻久久久一区二区三区 | 精品国产VA久久久久久久冰| 久久精品国产久精国产果冻传媒| 久久久WWW成人免费毛片| 久久中文字幕一区二区| 久久精品国产99国产电影网| 久久久噜噜噜久久中文福利| 久久综合给久久狠狠97色| 狠狠色噜噜色狠狠狠综合久久| 久久精品成人欧美大片| 久久天天躁夜夜躁狠狠| 久久午夜福利无码1000合集| 久久精品aⅴ无码中文字字幕不卡 久久精品成人欧美大片 | 麻豆成人久久精品二区三区免费| 97精品伊人久久久大香线蕉| 亚洲午夜无码久久久久| 久久精品国产亚洲av水果派 | 日韩美女18网站久久精品| 日韩va亚洲va欧美va久久|