青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
On The Road
(cond ((less 'code) (less 'bug)))
C++博客
首頁
新隨筆
聯(lián)系
聚合
管理
隨筆 - 119 文章 - 290 trackbacks - 0
博客搬家了哦,請移步
叫我abc
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
《GAME PROGRAMMING GEMS6》讀書筆記(4)
《UNIX編程藝術(shù)》讀書筆記(4)
month-flow(5)
mysql入門(3)
垃圾收集(4)
我的博客
叫我abc
博客搬家啦
搜索
積分與排名
積分 - 306721
排名 - 84
最新評論
1.?re: C++ std::fstream open mode
i'am got
--hdj
2.?re: cppcheck的使用
你好,你會使用cppcheck嗎?@robert
--wqq
3.?re: 垃圾收集的那點事(H)
非常感謝
--7Qing_
4.?re: 高效調(diào)用lua函數(shù)
為什么提示沒有findLuaItem這個函數(shù)?
--sdfasf
5.?re: android ndk調(diào)試知識[未登錄]
博主你好,請問如果沒有.so的源代碼,應(yīng)該如何進行arm的匯編級調(diào)試呢?
--dennis
閱讀排行榜
1.?cppcheck的使用(17097)
2.?十步精通新語言(10707)
3.?內(nèi)存池實現(xiàn)(9909)
4.?高效調(diào)用lua函數(shù)(9278)
5.?在lua腳本中使用unicode(8258)
垃圾收集的那點事(J)
繼
stack_pack
將堆棧中的內(nèi)存和所分配的函數(shù)之間建立依賴關(guān)系之后,就到了對 E.pool中所有管理的內(nèi)存進行標記的時候了。
1
static
void
2
gc_mark(
int
root)
3
{
4
if
(E.pool[root].mark
<
E.mark
+
1
)
{
5
struct
link
*
children
=
E.pool[root].u.n.children;
6
E.pool[root].mark
=
E.mark
+
1
;
7
if
(children)
{
8
int
i;
9
10
for
(i
=
children
->
number
-
1
;i
>=
0
;i
--
)
{
11
gc_mark(children
->
children[i]);
12
}
13
}
14
}
15
}
由于暫時還不想考慮weak table的內(nèi)容,我暫時將這一部分的代碼去掉。
來看看是如何對內(nèi)存隊列進行標記的。首先,形參root是依賴關(guān)系的父節(jié)點,是 E.pool數(shù)組中的索引。在gc_collect中 root = 0,表示從全局根節(jié)點開始,更準確的說從main函數(shù)對象開始,遍歷整個依賴關(guān)系構(gòu)成的樹,對每一個節(jié)點進行標記。
第4行,是對節(jié)點是否已經(jīng)被標記的判斷。第6行對該節(jié)點進行標記。第10、11行則對該節(jié)點所引用的子節(jié)點重復(fù)這一標記過程。
整個依賴關(guān)系是樹狀的,利用先序遍歷標記所有還被引用的內(nèi)存節(jié)點。這就是
gc_mark
所作的工作。
最后,是對所有沒有標記過的內(nèi)存進行回收。
1
for
(i
=
0
;i
<
E.size;i
++
)
{
2
if
(E.pool[i].mark
<
E.mark)
{
3
if
(E.pool[i].mark
>=
0
)
{
4
void
*
p
=
E.pool[i].u.n.mem;
5
if
(E.pool[i].u.n.finalizer
&&
E.pool[i].u.c.weak
!=
WEAK_CONTAINER)
{
6
E.pool[i].u.n.finalizer(p);
7
}
8
if
((intptr_t)p
!=
FREED_POINTER)
{
9
my_free(p);
10
map_erase(i);
11
}
12
node_free(i);
13
}
14
}
15
else
if
(E.pool[i].mark
==
E.mark)
{
16
void
*
p
=
E.pool[i].u.n.mem;
17
if
(E.pool[i].u.n.finalizer
&&
E.pool[i].u.c.weak
!=
WEAK_CONTAINER)
{
18
E.pool[i].u.n.finalizer(p);
19
E.pool[i].u.n.finalizer
=
0
;
20
}
21
my_free(p);
22
map_erase(i);
23
E.pool[i].u.c.mem
=
FREED_POINTER;
24
}
25
}
用for循環(huán)遍歷 E.pool,所有分配的內(nèi)存,因為被標記的內(nèi)存的值是 E.mark + 1,所以只要 E.pool[i].mark <= E.mark的,都算是垃圾內(nèi)存了,因此for循環(huán)里面的兩個 if 和 else if在垃圾內(nèi)存的角度上并沒有差別,都是被回收的內(nèi)容,但是這兩個代碼塊多少還是有差異的,因此稍微想了一下。
首先,從之前做標記的代碼看,沒有被標記過的內(nèi)存應(yīng)該是小于 E.mark的,因此if代碼塊是理解上的正常流程。而else if 部分,檢測內(nèi)存的標記等于 E.mark,這個怎么看都是沒有可能的,因為標記值是 E.mark+1,而E.mark以+2遞增。這有可能是其他一些我還沒看過的代碼,對節(jié)點進行了標記也說不定,畢竟還有一個weak_table沒有接觸呢。
此外還有一個細節(jié),else if部分,沒有調(diào)用node_free(i),釋放了內(nèi)存,但是節(jié)點保留著,這讓我更確認這是一塊還沒有開辟的代碼區(qū)域造成的,不過,這還是等以后看到相關(guān)內(nèi)容的時候,再來考證這里的內(nèi)容吧。
最后,來看看gc_link中解除依賴關(guān)系的代碼,現(xiàn)在已經(jīng)對整個gc庫有了整體的認識,這部分代碼也就不在話下了
1
if
(prev)
{
2
int
prev_id
=
map_id(prev);
3
stack_push(prev_id);
4
node_add(parent_id,prev_id
|
UNSET_MASK);
5
}
第3行,將被解除關(guān)系的內(nèi)存id壓入堆棧,看起來目的是讓這塊內(nèi)存再稍微活長久一點,至少要活到離開當前函數(shù)后。
然后第4行,解除了之前主動添加的依賴關(guān)系,在cache_flush的時候,將會從children數(shù)組中刪除prev_id。
posted on 2008-09-22 21:55
LOGOS
閱讀(4903)
評論(4)
編輯
收藏
引用
所屬分類:
垃圾收集
FeedBack:
#
re: 垃圾收集的那點事(J) 2008-09-22 22:44
來支持
都還沒去下過云風(fēng)原始的代碼,到是從博主這里看出一點頭緒來,這么感覺出有點LUA的味道啊。對lua研究不深,隨便說說,呵呵。
回復(fù)
更多評論
#
re: 垃圾收集的那點事(J) 2008-09-23 10:32
cexer
哪里有下載的源碼
回復(fù)
更多評論
#
re: 垃圾收集的那點事(J) 2008-09-23 10:57
LOGOS
@cexer
http://manualgc.googlecode.com/svn/trunk
回復(fù)
更多評論
#
re: 垃圾收集的那點事(J)
2008-09-23 17:40
cexer
@LOGOS
多謝了,我也研究研究。
回復(fù)
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發(fā)表評論。
相關(guān)文章:
gc庫概念簡化版
垃圾收集的那點事(K)
垃圾收集的那點事(J)
垃圾收集的那點事(A)
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 LOGOS Powered by:
博客園
模板提供:
滬江博客
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
久久深夜福利
|
蜜桃伊人久久
|
久久免费少妇高潮久久精品99
|
香蕉成人伊视频在线观看
|
99热在线精品观看
|
亚洲视频一二区
|
亚洲欧美国产毛片在线
|
午夜免费在线观看精品视频
|
久久精品盗摄
|
亚洲人成77777在线观看网
|
亚洲福利免费
|
亚洲精品国精品久久99热一
|
亚洲国产裸拍裸体视频在线观看乱了中文
|
亚洲激情视频网
|
日韩小视频在线观看专区
|
亚洲精选一区
|
午夜精品久久久久久久男人的天堂
|
亚洲综合电影
|
美女在线一区二区
|
一区二区久久
|
久久九九久精品国产免费直播
|
麻豆成人在线播放
|
国产亚洲欧美一区在线观看
|
羞羞色国产精品
|
亚洲第一网站
|
午夜精品久久久久久久99热浪潮
|
久久精品视频播放
|
欧美精品综合
|
国产日韩在线看
|
99国产精品久久久久久久久久
|
欧美一区网站
|
亚洲色图制服丝袜
|
美女精品一区
|
国内精品久久久久伊人av
|
香蕉视频成人在线观看
|
欧美日韩亚洲另类
|
91久久国产综合久久
|
久久全国免费视频
|
亚洲欧美在线磁力
|
国产精品男女猛烈高潮激情
|
亚洲毛片在线看
|
91久久精品国产91性色
|
免费不卡在线观看av
|
亚洲日本欧美在线
|
亚洲啪啪91
|
欧美性一二三区
|
欧美一区二区久久久
|
亚洲一区二区三区在线视频
|
欧美日韩国内
|
亚洲一区中文字幕在线观看
|
午夜精品短视频
|
在线观看日韩
|
一本一本久久a久久精品综合妖精
|
国产精品sm
|
欧美1区2区
|
国产精品v日韩精品
|
久久国产欧美日韩精品
|
免费一级欧美片在线观看
|
亚洲精品久久久久久久久久久
|
亚洲人成人77777线观看
|
欧美国产一区二区在线观看
|
亚洲无人区一区
|
欧美一区永久视频免费观看
|
最近中文字幕mv在线一区二区三区四区
|
免费高清在线视频一区·
|
久久日韩精品
|
一区二区三区国产在线
|
新片速递亚洲合集欧美合集
|
在线精品一区
|
亚洲网站啪啪
|
亚洲人体偷拍
|
久久免费精品日本久久中文字幕
|
一区二区福利
|
噜噜噜在线观看免费视频日韩
|
欧美经典一区二区三区
|
欧美影院在线
|
欧美日本韩国一区
|
卡通动漫国产精品
|
国产精品久久久亚洲一区
|
亚洲国产另类久久精品
|
国产一区二区三区高清
|
亚洲最新合集
|
日韩亚洲在线
|
欧美国产在线电影
|
亚洲国产精品v
|
亚洲美女精品成人在线视频
|
一区二区三区免费观看
|
老司机免费视频一区二区
|
久久综合影音
|
亚洲精品欧美专区
|
欧美高清hd18日本
|
亚洲激情成人
|
久久久久久久精
|
欧美电影电视剧在线观看
|
亚洲韩日在线
|
欧美激情第一页xxx
|
999在线观看精品免费不卡网站
|
亚洲精品小视频
|
欧美日韩国产综合视频在线观看中文
|
中文日韩欧美
|
亚洲免费成人
|
欧美日韩中文精品
|
香蕉久久久久久久av网站
|
久久久久久亚洲精品不卡4k岛国
|
国产综合色一区二区三区
|
久久免费视频这里只有精品
|
亚洲精品免费在线播放
|
亚洲欧美卡通另类91av
|
一区在线影院
|
欧美三级电影一区
|
久久久777
|
99精品热6080yy久久
|
久久婷婷国产麻豆91天堂
|
亚洲人成人99网站
|
国产一区二区
|
国产精品久久久久国产a级
|
亚洲精品永久免费精品
|
国产精品午夜视频
|
亚洲精品一级
|
国产在线日韩
|
欧美黑人多人双交
|
久久精品一区二区三区不卡牛牛
|
亚洲欧美日韩视频一区
|
美女脱光内衣内裤视频久久影院
|
欧美不卡在线视频
|
国产精品久久久久久久久借妻
|
国产一区二区日韩精品
|
亚洲精品在线看
|
久久婷婷蜜乳一本欲蜜臀
|
亚洲狠狠婷婷
|
久久国产毛片
|
国产精品久久久久一区二区
|
尤物精品在线
|
性娇小13――14欧美
|
亚洲国产婷婷
|
久久久亚洲国产美女国产盗摄
|
欧美色欧美亚洲另类二区
|
亚洲高清免费在线
|
欧美资源在线观看
|
亚洲天堂免费观看
|
国产精品人人做人人爽
|
午夜精品久久久久久久99热浪潮
|
亚洲欧美国产精品va在线观看
|
国产麻豆一精品一av一免费
|
久久免费视频观看
|
麻豆国产精品va在线观看不卡
|
国产精品yjizz
|
狼人社综合社区
|
欧美精品一区二区三区在线看午夜
|
亚洲午夜91
|
久久久久久久综合
|
在线亚洲精品福利网址导航
|
亚洲女人天堂成人av在线
|
亚洲国产婷婷香蕉久久久久久
|
日韩一区二区高清
|
欧美专区在线播放
|
国产精品久久7
|
欧美怡红院视频一区二区三区
|
亚洲午夜精品国产
|
国产精品制服诱惑
|
老司机午夜精品视频
|
麻豆成人精品
|
亚洲综合视频一区
|
午夜一区二区三区不卡视频
|
国产一区二区三区久久精品
|
暖暖成人免费视频
|
欧美日韩国产色站一区二区三区
|
在线视频亚洲欧美
|
久久国产高清
|
一区二区动漫
|
香蕉成人啪国产精品视频综合网
|
激情久久一区
|
日韩一二在线观看
|
在线免费观看日本欧美
|
亚洲精品在线观
|
激情久久综艺
|
亚洲在线第一页
|
亚洲靠逼com
|
久久久亚洲精品一区二区三区
|
一区二区三区四区五区视频
|
亚洲欧美另类中文字幕
|
欧美成人免费全部
|
久久久精品性
|
国产精品久久久久久av福利软件
|
欧美在线一二三区
|
国产精品乱码一区二区三区
|
亚洲福利视频一区
|
曰本成人黄色
|
久久综合九色综合欧美狠狠
|
欧美在线短视频
|
美女诱惑黄网站一区
|
一区二区三区日韩欧美
|
中文日韩在线
|
亚洲国产成人在线视频
|
欧美激情无毛
|
欧美激情按摩
|
亚洲二区在线视频
|
亚洲高清二区
|
久久这里只有
|
乱中年女人伦av一区二区
|