免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3335 | 回复: 5
打印 上一主题 下一主题

[算法] 对于"边界标识法"的一个疑问,感觉foot节点是多余的 [复制链接]

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:16:532015元宵节徽章
日期:2015-03-06 15:53:22
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-07-08 22:33 |只看该作者 |倒序浏览
严蔚敏的<<数据结构>>第8.3是将边界标识法,(boundary tag method),我没搞清楚foot节点到底有什么作用:
既然可分配空间是用双向链表标识的,我们都知道双向聊表可以双向访问,那么当前结点通过llink访问前驱节点,通过rlink访问后继节点,就完全可以了。
那么foot节点存在的意义是什么? 我认为不是必须存在的,因为要求下一个节点的位置,直接llink或者rlink跳转就可以了,为什么还要foot呢?

还请指教!

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
2 [报告]
发表于 2016-07-09 11:34 |只看该作者
回复 1# cdsfiui


    确实不是必须的,从图上看,只是为了方便找到空闲块的头。BTW,Glibc malloc 用的就是 boundary tag method,可以找出来参考下。

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:16:532015元宵节徽章
日期:2015-03-06 15:53:22
3 [报告]
发表于 2016-07-09 14:06 |只看该作者
回复 2# MMMIX


    要找到空闲块的头,用llink/rlink查找前驱/后继节点就可以了啊,为什么用这个foot能方便查找呢?
    谢谢。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
4 [报告]
发表于 2016-07-09 15:18 |只看该作者
本帖最后由 MMMIX 于 2016-07-09 15:24 编辑
cdsfiui 发表于 2016-07-09 14:06
回复 2# MMMIX

要找到空闲块的头,用llink/rlink查找前驱/后继节点就可以了啊,为什么用这个foot能方便查找呢?


你要是只有一个空闲块的结尾地址呢?没有它的大小,你怎么找到该块的开头? 例如说在释放一个块的时候,若是要检查是否要和前面的块合并,这时候有 foot 就很方便了,不然的话你还得在空闲列表中搜索一遍。

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:16:532015元宵节徽章
日期:2015-03-06 15:53:22
5 [报告]
发表于 2016-07-09 22:58 |只看该作者
回复 4# MMMIX


    看是否要和前面的块合并,我通过llink找到前面块的head,看它的tag就行了。并不需要重新查找一遍空闲块列表吧?
    还是没有太跟上你的节奏,可否继续解释一下?

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2016-07-10 22:49 |只看该作者
cdsfiui 发表于 2016-07-09 22:58
回复 4# MMMIX

看是否要和前面的块合并,我通过llink找到前面块的head,看它的tag就行了。并不需要重新查找一遍空闲块列表吧?


我说的前面的块,是在内存(地址)中和当前块挨着的块,不是链表中的前面的块。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP