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

隨筆 - 119  文章 - 290  trackbacks - 0

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

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 306395
  • 排名 - 84

最新評論

閱讀排行榜

先說下背景,有同學看了我寫的yfgc庫的分析,留言問我能不能用c實現一個教學用gc庫,力求簡單,無需優化。這個月實在寫不出blog,正好充數一篇。
相關連接: http://m.shnenglu.com/darkdestiny/archive/2008/09.html

真正能用的gc庫我不會寫,簡單表達問題本質的東西倒還能應付,就寫了一下。不過只用c沒有容器是不行的,用了stl,相信同學能看明白。
首先還是先說一下基本概念,gc本質就是把你分配出去的內存都記好了,倆倆內存之間的依賴關系都記好了。回收的時候查找依賴關系,將被根節點依賴的內存都標記為不可刪除,刪除沒有被標記的內存即可。
說實話,gc對于c/cpp這種中級語言意義不大,因為你不得不手動修改兩塊內存之間的依賴關系,這和手動管理內存是沒有差別的。你忘了解除依賴關系,等價于忘了釋放內存。
gc這種東西,只對于能把指針變量進行特殊編譯的編譯器,或者基于虛擬機的語言有價值。我用c/cpp的話還是傾向于手動管理內存,不管依賴關系如何復雜,只要所有權內保證唯一就可單點手動釋放;對于所有權不唯一的依賴關系,則采用引用計數機制。

話說太多了,貼點代碼吧,也許改改就能編譯過去。
#define ROOT (void*)NULL

void* gc_malloc(size_t s);
void gc_link(void* parent, void* child);
void gc_unlink(void* parent, void* child);
void gc_collect();


#include 
<map>
static std::multimap<void*,void*> s_links, s_linkClean;
static std::map<void*,int> s_allPtrs;
static int s_color = 0;


void* gc_malloc(size_t s)
{
    
void* ptr = ::malloc(s);
    s_allPtrs[ptr] 
= s_color;
    
return ptr;
}

void gc_link(void* parent, void* child)
{
    s_links.insert(std::make_pair(parent,child));
}

void gc_unlink(void* parent, void* child)
{
    s_links.erase(std::make_pair(parent, child));
}

void gc_collect()
{
    s_color 
= (s_color+1% 2;
    gc_mark_r(ROOT);
    s_links 
= s_linkClean;
    s_linkClean.clear();

    auto iter 
= s_allPtrs.begin();
    
while(iter!=s_allPtrs.end())
    {
        auto cur 
= iter++;
        
if(cur->second != s_color)
        {
            ::free(cur
->first);
            s_allPtrs.erase(cur);
        }
    }
}

void gc_mark_r(void* parent)
{
    
if(parent!=ROOT && s_allPtrs[parent]==s_color)
    {
        
return;
    }
    s_allPtrs[parent] 
= s_color;

    auto iter 
= s_links.lower_bound(parent);
    auto end 
= s_links.upper_bound(parent);
    
for(; iter!=end; ++iter)
    {
        s_linkClean.insert(iter);
        
void* child = iter->second;
        gc_mark_r(child);
    }
}

int main()
{
    
void* p1 = gc_malloc(10);
    gc_link(ROOT, p1);
    
void* p2 = gc_malloc(20);
    gc_link(p1, p2);
    gc_collect();
    
return 0;
}

yfgc庫里的gc_enter/gc_leave是實現在gc_link/gc_unlink上的,算拓展api吧。同學完全可以自己實現的,hint是,為每個函數調用分配一點內存,建立父子函數內存上的依賴關系,函數里分配的臨時內存和函數對應的內存也建立依賴關系,函數退出時解除相關的依賴關系。

云風不久前又給出一個基于繼承的gc解決方案,很簡單,可以看看:
http://blog.codingnow.com/2010/02/cpp_gc.html
posted on 2010-04-29 21:13 LOGOS 閱讀(2974) 評論(6)  編輯 收藏 引用 所屬分類: 垃圾收集

FeedBack:
# re: gc庫概念簡化版 2010-04-30 09:42 Kevin Lynx
- - 果然需要自己“改改才能編譯過去”。。  回復  更多評論
  
# re: gc庫概念簡化版 2010-04-30 10:23 Kevin Lynx
每一次調用gc_collect的時候,s_color變為對立值(0->1, 1->0),然后gc_mark_r將位于s_links中的指針全部標記為當前的s_color值,那么在gc_collect之前gc_unlink的指針依然為原來的s_color,即未被標記,然后gc_collect回收這些未被標記的指針(指向的內存)。

不是很明白,s_linkClean在這里的作用。  回復  更多評論
  
# re: gc庫概念簡化版 2010-04-30 10:35 LOGOS
@Kevin Lynx
假設links中有這些值
root->a,a->b,b->c
當root->a被刪除后,links的值為
a->b,b->c
結果a,b,c都被回收了,而這些鏈接關系都是無效的關系,需要清理
s_linkClean用于記錄有效的鏈接關系  回復  更多評論
  
# re: gc庫概念簡化版[未登錄] 2010-04-30 11:03 houapple
先謝謝LOGOS的回復,早上起來就看自己想看到的,心情那個愉悅啊!呵呵!
恩,剛剛把程序仔細看完,大概明白了程序的思想。
有兩個問題:
1、如果我們不顯式調用 gc_link 去維護依賴關系,如何去知道哪些內存需要回收?
2、因為大部分內存泄露都在被調用的函數中發生。如果我希望如下使用:
main()
{
gc_init();
foo();
gc_collect();
}
當然foo()中內存分配函數使用gc_malloc()。應該用什么機制去實現?  回復  更多評論
  
# re: gc庫概念簡化版 2010-04-30 11:56 LOGOS
@houapple
1.不調用gc_link,所有內存都會被回收
2.
foo()
{
gc_enter();
...
gc_leave();
}
gc_enter分配一個表示函數調用的內存p,修改gc_malloc,分配出c時默認和函數調用棧頂的內存建立依賴關系即可:gc_link(p,c)
gc_leave刪除當前函數和上一個函數的依賴關系:gc_unlink(p-1, p)  回復  更多評論
  
# re: gc庫概念簡化版[未登錄] 2010-04-30 14:22 houapple
第一點明白了,第二點考慮中!
謝謝 LOGOS  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              亚洲第一黄网| 日韩网站在线观看| 美女性感视频久久久| 久久se精品一区精品二区| 亚洲一品av免费观看| 日韩天天综合| 最新亚洲一区| 欧美午夜电影在线观看| 欧美午夜精品理论片a级按摩| 亚洲视频一二区| 亚洲黄色大片| 亚洲国产一区二区精品专区| 久久精品亚洲乱码伦伦中文| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 在线视频亚洲欧美| 欧美大片国产精品| 亚洲欧洲精品天堂一级 | 激情久久久久久久| 精品电影在线观看| 亚洲福利精品| 99日韩精品| 香蕉久久国产| 欧美xart系列高清| 欧美色欧美亚洲高清在线视频| 欧美日韩精品伦理作品在线免费观看| 欧美久久成人| 国产精品视频午夜| 亚洲国产欧洲综合997久久| 伊人狠狠色j香婷婷综合| 正在播放欧美视频| 一本色道久久综合亚洲精品高清| 亚洲视频免费| 欧美激情精品久久久久| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久久xxx| 亚洲天堂成人在线视频| 巨胸喷奶水www久久久免费动漫| 你懂的网址国产 欧美| 欧美午夜视频| 亚洲国产乱码最新视频| 欧美一区二区三区四区视频| 亚洲国产第一页| 欧美在线影院在线视频| 欧美午夜激情在线| 一级成人国产| 欧美一区二区免费观在线| 亚洲精品免费网站| 久久一区二区精品| 亚洲第一福利社区| 欧美在线一区二区三区| 亚洲乱亚洲高清| 红桃视频成人| 免费精品视频| 欧美网站在线| 奶水喷射视频一区| 欧美成人精品在线播放| 亚洲天堂av图片| 亚洲欧美综合精品久久成人| 国产精品美女久久福利网站| 麻豆av福利av久久av| 欧美性猛交xxxx乱大交蜜桃| 久久久久久精| 欧美精品一区二区三区蜜臀| 欧美在线免费视屏| 欧美日韩91| 国产精品国产三级国产普通话99 | 亚洲综合日韩在线| 最近看过的日韩成人| 亚洲欧美国产va在线影院| 亚洲精品免费在线播放| 久久精品视频免费观看| 亚洲天堂网站在线观看视频| 美女视频一区免费观看| 欧美亚洲免费电影| 国产精品不卡在线| 欧美一区二区三区四区在线| 欧美成人一区二区三区在线观看| 久久激情五月丁香伊人| 国产精品人人爽人人做我的可爱| 一本久久a久久精品亚洲| 亚洲午夜电影网| 国产精品一区二区你懂的| 亚洲一区二区免费| 久久久99久久精品女同性 | 在线中文字幕日韩| 亚洲视频1区2区| 国产欧美日本一区二区三区| 亚洲伊人网站| 免费成人av在线看| 亚洲美女精品久久| 国产精品欧美日韩一区| 性刺激综合网| 亚洲黄色大片| 亚洲午夜久久久久久久久电影院| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲私人影院在线观看| 欧美福利网址| 一区二区三区国产在线| 久久影视精品| 欧美在线观看你懂的| 亚洲乱码视频| 最新日韩欧美| 国产日本欧洲亚洲| 欧美片第一页| 欧美成人精品| 美腿丝袜亚洲色图| 久久精品免费播放| 欧美一级片在线播放| 亚洲视频免费看| 亚洲美女视频在线观看| 欧美xxxx在线观看| 久久久www免费人成黑人精品 | 亚洲国产欧美一区二区三区久久| 欧美日韩亚洲国产一区| 欧美顶级大胆免费视频| 免费在线视频一区| 女人天堂亚洲aⅴ在线观看| 久久精品一级爱片| 老色鬼久久亚洲一区二区| 美日韩丰满少妇在线观看| 老司机一区二区三区| 欧美电影在线观看完整版| 欧美久久久久| 国产欧美日韩亚洲精品| 国产一区二区三区四区在线观看| 国产精品久久久久久久一区探花| 国产一区二区日韩| 久久高清福利视频| 性欧美大战久久久久久久免费观看| 欧美第一黄色网| 怡红院精品视频在线观看极品| 欧美在线观看你懂的| 欧美性色aⅴ视频一区日韩精品| 亚洲福利视频专区| 国产精品推荐精品| 国产精品99久久久久久久久| 亚洲国产精品一区二区www在线| 久久夜色撩人精品| 亚洲精品国产精品国自产观看浪潮 | 亚洲日韩欧美视频| 亚洲电影免费观看高清完整版在线观看 | 亚洲欧美在线网| 影音欧美亚洲| 日韩视频在线一区二区| 国产精品二区二区三区| 久久av免费一区| 欧美电影资源| 久久久国产精彩视频美女艺术照福利| 欧美亚洲在线视频| 亚洲精选91| 久久精品国产亚洲5555| 99国产精品久久久久久久| 亚洲一区二区三区影院| 精品av久久707| 亚洲视频 欧洲视频| 亚洲成色777777女色窝| 一区二区三区回区在观看免费视频| 国产日韩欧美在线观看| 亚洲第一二三四五区| 国产一区二区三区在线播放免费观看 | 国产三级精品三级| 最新日韩在线| 国产主播一区| 亚洲乱码国产乱码精品精天堂| 欧美午夜不卡在线观看免费 | 91久久国产综合久久蜜月精品 | 99精品视频免费全部在线| 欧美激情第一页xxx| 欧美三区在线观看| 久久国产福利| 欧美日韩在线一二三| 美腿丝袜亚洲色图| 国产精品日韩在线| 亚洲精品视频在线看| 亚洲黄色三级| 嫩草成人www欧美| 免费看成人av| 欧美午夜一区二区| 亚洲一区二区三区乱码aⅴ| 亚洲一区免费| 国产亚洲精品资源在线26u| 久久精品国产欧美亚洲人人爽| 午夜在线a亚洲v天堂网2018| 欧美三级特黄| 久久大香伊蕉在人线观看热2| 亚洲欧美日韩精品一区二区| 国产精品毛片a∨一区二区三区|国 | 在线日韩中文| 久久久国产午夜精品| 免费成人小视频| 亚洲精品午夜精品| 欧美成人激情在线| 亚洲精品自在在线观看| 日韩视频免费在线| 欧美日韩精品免费观看视一区二区| 亚洲精品国久久99热| 亚洲一区二区三区视频播放| 国内免费精品永久在线视频| 欧美成人一二三| 亚洲欧美日韩电影|