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

posts - 18,  comments - 104,  trackbacks - 0
上篇說(shuō)到垃圾回收器的一些基本原理。這次說(shuō)說(shuō)這個(gè)垃圾回收器最終效果啥呀。有著明確的需求,說(shuō)起來(lái)會(huì)更清晰,更明確。

看代碼吧。

struct A
{
    int i,j,k;

    Begin_Member_Pointer(A)
    End_Member_Pointer

    
};


struct B
{
    pointer<A> data0;

    B()
    {
        data0 = gc.malloc<A>();
    }

    Begin_Member_Pointer(B)
    Member(data0);
    End_Member_Pointer

};

pointer<B> test()
{
    pointer<B> pB = gc.malloc<B>();
    //做一些事情
    return pB;
}

void main()
{
    pointer<B> pB = test();
    //做一些事情
    gc.collect();
    gc.compress();

}

看看上面的一段代碼,基本演示了怎么用這個(gè)垃圾回收器。

1.  gc.malloc< >(  ) 為對(duì)象分配空間,并調(diào)用構(gòu)造函數(shù)。gc.malloc有多個(gè)參數(shù)的模板函數(shù),構(gòu)造函數(shù)的參數(shù)直接放里面就可以。
2.  能被垃圾回收器回收的對(duì)象,必須定義一個(gè)以Begin_Member_Pointer(TypeName) 開(kāi)始,以End_Member_Pointer結(jié)束,中間包含所有pointer類(lèi)型成員變量的列表(順序無(wú)關(guān))。
3.  在任意時(shí)候調(diào)用gc.collect(  )來(lái)回收所有無(wú)用內(nèi)存,并會(huì)對(duì)所有被回收的對(duì)象調(diào)用析構(gòu)函數(shù)。
4.  在回收后可以選擇調(diào)用gc.compress(  )來(lái)緊縮內(nèi)存。

當(dāng)然現(xiàn)在如果有朋友讀過(guò)源碼,會(huì)發(fā)現(xiàn)和上面所有有些不一致,不過(guò)上面是最終的效果。

這里就對(duì)指針的使用有了一些限制,

1. 所有受垃圾回收器控制的內(nèi)存的指針是以 pointer<type> 的形式存在,而且是強(qiáng)制的。pointer類(lèi)型不能轉(zhuǎn)化成普通指針,而且gc.malloc函數(shù)返回的也是pointer類(lèi)型的指針,這個(gè)是必須的,因?yàn)橐獙?shí)現(xiàn)內(nèi)存緊縮,所有的指針必須受控)。
2. 所有的類(lèi)型定義里面必須包含對(duì)成員指針的一個(gè)描述,見(jiàn)上面第2條。否則想上面在B的構(gòu)造函數(shù)中申請(qǐng)出來(lái)的A對(duì)象就無(wú)法被釋放了。

這些對(duì)成員的描述就是上面圖中粉紅色圓圈的指針了,如果沒(méi)有這些定義,有些內(nèi)存塊的可達(dá)性判斷就可能失效。

這里我做了一些簡(jiǎn)化,暫時(shí)不考慮多核多線程,所以寄存器可以不考慮,這大幅降低了編碼的復(fù)雜度,使得代碼更容易理解。

先看看所有的數(shù)據(jù)結(jié)構(gòu)吧:

//掃描成員指針的函數(shù)指針
typedef void (*marker) (const void* ptr, void(*func)(const pointer_base&));

//根集
std::list<pointer_base *> gc_root_set;

//內(nèi)存塊節(jié)點(diǎn)
struct node
{
    
void* mem;        //內(nèi)存指針(普通指針)
    unsigned int size;    //內(nèi)存大小
    unsigned int mark;    //當(dāng)前的標(biāo)志
    marker func;        //掃描函數(shù)指針
    destructor finalizer;    //析構(gòu)函數(shù)指針
}
;

//內(nèi)存塊集
std::map<const void *, node> gc_holder;
//標(biāo)志
unsigned int gc_marker = 0;
//標(biāo)志當(dāng)前指針是否屬于根集
bool gc_is_root_set_locked = false;
//所有指針集(用于緊縮)
std::multimap<const void*const pointer_base*> gc_pointer_set;
//緊縮時(shí)用的緩沖
std::map<const void*const void*> gc_swap_buffer;

上面就是全部的數(shù)據(jù)結(jié)構(gòu),需要說(shuō)明的是:
1。 那個(gè)marker是一個(gè)函數(shù)指針,它的第二個(gè)參數(shù)也是個(gè)函數(shù)指針。
2。 了解C++的朋友可能會(huì)說(shuō),析構(gòu)函數(shù)不能對(duì)其取地址。當(dāng)然這里用了一個(gè)小小的技巧---對(duì)析構(gòu)函數(shù)進(jìn)行了包裝。

template <class _T>
void gc_destructor(_T* p)
{
    p
->_T::~_T();
}
;

typedef 
void (*destructor) (void*);

struct node
{
    
void* mem;
    unsigned 
int size;
    unsigned 
int mark;
    marker func;
    
//注意類(lèi)型
    destructor finalizer;
}
;

node n;
//這是關(guān)鍵
n.finalizer = (destructor)&gc_destructor<_T>;

 

3。 注意gc_mark不是一個(gè)bool變量,它會(huì)隨著每次分配而++,在collect之前,會(huì)用++mark來(lái)標(biāo)記所有可達(dá)內(nèi)存塊,即node.mark = gc_mark; 于是,所有mark值和gc_mark不等的內(nèi)存塊就需要被回收啦。

從下篇開(kāi)始就逐個(gè)介紹各個(gè)函數(shù)了,最后再用宏或模板做出來(lái)一些語(yǔ)法糖,把見(jiàn)不得人的東西都包起來(lái),就大功告成了。

posted on 2010-02-10 19:09 尹東斐 閱讀(2647) 評(píng)論(10)  編輯 收藏 引用

FeedBack:
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-10 19:54 | jimmy
果然大牛?。。?nbsp; 回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-12 12:23 | Benjamin
如果能考慮一下異常,會(huì)完整些  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-13 12:00 | yindf
@Benjamin

完成了會(huì)考慮的,謝謝支持。  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-18 12:04 | 路過(guò)
失敗的垃圾設(shè)計(jì),買(mǎi)本《垃圾收集》來(lái)看看好不?  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-18 20:01 | yindf
@路過(guò)

呵呵~~你看過(guò)的話(huà)在C++下實(shí)現(xiàn)一個(gè)吧,我求你了。  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-18 21:53 | 路過(guò)
《Garbage Collection》Jones, Richard/ Lins, Rafael著,
強(qiáng)烈建議仔細(xì)讀讀這本書(shū),去看看HP CPPGC源碼。概念不清,常識(shí)性錯(cuò)誤。
唉。。。  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-19 02:25 | yindf
@路過(guò)

HP gc看過(guò)啦,我在上篇提到過(guò),HP gc有它的缺點(diǎn)。
C++不能完全控制指針,所以HP gc說(shuō)過(guò),它是“保守的”垃圾回收。

而我這個(gè),就是精確的。  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-20 00:15 | 路過(guò)
精確的?!Are you kidding?!  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-02-20 22:41 | yindf
@路過(guò)

呵呵,只要是用gc malloc 分配出來(lái)的,都可以保證在不用的時(shí)候,通過(guò)collect收集。 HP gc不行。  回復(fù)  更多評(píng)論
  
# re: C++下垃圾回收器的實(shí)現(xiàn)(二)--析構(gòu)函數(shù)的地址?
2010-04-06 09:30 | 不知所謂
樓主你去看看樓上說(shuō)的那本書(shū)好不咯?你這個(gè)所謂gc簡(jiǎn)直就是幼稚得搞笑  回復(fù)  更多評(píng)論
  

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


<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(4)

隨筆檔案

文章分類(lèi)

文章檔案

相冊(cè)

好友博客

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品成人欧美大片古装| 欧美日韩影院| 欧美国产欧美亚洲国产日韩mv天天看完整| 午夜在线一区| 久久精品噜噜噜成人av农村| 午夜在线精品| 久久精品国产在热久久| 欧美电影免费观看大全| 国产一级揄自揄精品视频| 亚洲电影在线免费观看| 欧美一区二区日韩一区二区| 欧美国产欧美综合| 欧美一区二区高清| 欧美久久九九| 亚洲伦理久久| 狂野欧美一区| 国产精品99久久久久久有的能看| 欧美在线视频一区二区三区| 国产精品国内视频| 亚洲美女淫视频| 另类国产ts人妖高潮视频| 亚洲午夜电影网| 欧美日韩国产精品成人| 精品88久久久久88久久久| 欧美一级在线视频| 性欧美精品高清| 国产精品制服诱惑| 这里只有精品电影| 亚洲国产精品黑人久久久| 久热精品视频在线| 国产亚洲制服色| 亚洲麻豆av| 亚洲性xxxx| 国产精品一区二区三区四区| 亚洲免费一区二区| 欧美亚洲一级片| …久久精品99久久香蕉国产| 欧美电影在线观看完整版| 欧美专区第一页| 亚洲精品小视频在线观看| 老牛国产精品一区的观看方式| 欧美在线啊v一区| 加勒比av一区二区| 亚洲七七久久综合桃花剧情介绍| 欧美视频在线免费看| 久久免费黄色| 欧美日韩久久不卡| 99国内精品久久| 亚洲一区高清| 亚洲国产精品久久91精品| 亚洲人成人99网站| 国产精品有限公司| 欧美激情精品久久久久久变态| 欧美四级电影网站| av成人激情| 亚洲一区二区在线| 狠狠色丁香久久婷婷综合丁香| 亚洲欧美偷拍卡通变态| 亚洲五月婷婷| 亚洲精品免费电影| 亚洲免费在线视频| 一本色道久久| 老鸭窝91久久精品色噜噜导演| 一区二区三区四区五区精品视频| 亚洲天天影视| 激情一区二区三区| 亚洲欧美成人一区二区在线电影| 亚洲人永久免费| 久久精品视频一| 久久久久久穴| 欧美日韩网站| 欧美国产日韩一区二区三区| 狠狠爱www人成狠狠爱综合网 | 国产精品亚洲综合天堂夜夜| 亚洲激情校园春色| 狠狠久久亚洲欧美专区| 久久免费视频在线| 欧美在线播放| 国产精品久久久久天堂| 亚洲尤物在线| 亚洲无限av看| 国产在线拍偷自揄拍精品| 免费一级欧美片在线播放| 亚洲大片在线观看| 亚洲视频图片小说| 国产精品视频区| 欧美二区在线| 亚洲欧美日韩一区在线| 欧美+亚洲+精品+三区| 亚洲视频www| 在线电影欧美日韩一区二区私密| 欧美日韩xxxxx| 欧美在线日韩| 亚洲一区二区三区成人在线视频精品| 久久久久成人精品| 中日韩美女免费视频网站在线观看| 国产日韩在线亚洲字幕中文| 免费成人在线视频网站| 中文日韩欧美| 亚洲精品视频二区| 欧美成人精品在线| 久久免费偷拍视频| 亚洲自拍16p| 99pao成人国产永久免费视频| 在线观看欧美| 精品福利电影| 在线观看欧美日韩| 国产一区二区欧美日韩| 国产一区二区三区日韩| 亚洲精品在线视频观看| 亚洲大片精品永久免费| 久久精品国产一区二区电影 | 亚洲女人小视频在线观看| 狠狠操狠狠色综合网| 国内精品写真在线观看| 国产在线观看91精品一区| 国产嫩草影院久久久久| 国产午夜久久久久| 国产毛片精品视频| 国产欧美日韩三级| 狠狠色丁香婷婷综合影院| 在线观看av不卡| 国产精品免费一区二区三区在线观看 | 亚洲福利国产精品| 在线观看福利一区| 亚洲国产免费| 亚洲一区二区三区四区视频| 一本久久青青| 久久精品夜夜夜夜久久| 久久久久久国产精品mv| 裸体丰满少妇做受久久99精品| 久久精品国产精品 | 国内精品视频666| 亚洲精品视频啊美女在线直播| 一区二区三区精品视频| 欧美在线视频一区二区三区| 久久午夜国产精品| 亚洲国产三级在线| 亚洲欧美一区二区精品久久久| 久热re这里精品视频在线6| 欧美日韩精品伦理作品在线免费观看| 国产精品国产三级国产a| 国产一区二区三区久久| 亚洲线精品一区二区三区八戒| 农村妇女精品| 欧美一级视频免费在线观看| 欧美精品日韩一区| 国产亚洲一二三区| 亚洲午夜久久久久久久久电影网| 蜜臀久久久99精品久久久久久| 亚洲桃色在线一区| 欧美国产精品| 在线看一区二区| 欧美高清在线一区二区| 午夜久久久久| 国产麻豆综合| 亚洲欧美清纯在线制服| 99精品国产福利在线观看免费 | 国产女精品视频网站免费| 国产精品99久久99久久久二8 | 欧美高清自拍一区| 亚洲国产高清一区| 久久久久久婷| 欧美在线观看天堂一区二区三区 | 欧美电影免费观看高清| 国内精品视频666| 裸体丰满少妇做受久久99精品| 欧美专区一区二区三区| 精品不卡视频| 亚洲级视频在线观看免费1级| 欧美成人dvd在线视频| 亚洲精品国产无天堂网2021| 久久精品国产精品亚洲精品| 亚洲国产合集| 欧美成人精品| 好看不卡的中文字幕| 久久久亚洲综合| 欧美a级一区| 亚洲一二三区在线| 亚洲综合999| **欧美日韩vr在线| 亚洲国产天堂久久综合网| 国产精品国产a| 久久国产精品99国产精| 女仆av观看一区| 亚洲国产精品成人综合| 亚洲精品无人区| 韩日在线一区| 亚洲七七久久综合桃花剧情介绍| 蜜臀av性久久久久蜜臀aⅴ| 亚洲婷婷免费| 欧美激情按摩| 欧美成人午夜| 国产午夜久久| 亚洲欧美国产视频| 亚洲欧洲免费视频| 久久久福利视频| 久久天天躁夜夜躁狠狠躁2022| 国产精品一页| 亚洲精品资源|