免费注册 查看新帖 |

Chinaunix

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

[C] 请教各位,内存池 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-01-11 14:27 |只看该作者 |倒序浏览
请教各位

你们写的内存池,比直接向系统malloc,能快多少~

加上线程锁之后的结果


slab alloc-free result :
ExecTimes : 21 msecs , 982 usecs .

common alloc-free result :
ExecTimes : 30 msecs , 218 usecs .

以上是我自己写的内存池测试的结果。

论坛徽章:
0
2 [报告]
发表于 2008-01-11 17:46 |只看该作者
没统计过,不过我觉得肯定比每次都要申请快。

我觉得你的测试肯定不够全面,因为内存池只提供一个内存分配策略,这个策略视不同情况而不同,无所谓相互比较,关键还是要看特定的需求。

论坛徽章:
0
3 [报告]
发表于 2008-01-11 18:37 |只看该作者
我之感觉释放的时候,得遍历所有链表 所以很慢 !!!

论坛徽章:
0
4 [报告]
发表于 2008-01-11 19:26 |只看该作者
即使是基于链表的malloc,释放时也没有必要“遍历所有链表”。只有空闲链表搜索一小半就可以了。
buddy算法和slab就更没必要了。

自己写的malloc,主要是可以针对自己的内存使用情况做优化,比如对固定大小的内存分配做优化,效率可以做到很高。
通用设计的话,主要是在内存利用率和分配释放速度上进行权衡。

除非你的设计编码水平达到国际一流的水准,不然你写的malloc很难和编译器自带的相提并论。写编译器的人也不是吃白饭的。
如果不是特殊需求(比如通过浪费内存提高速度),建议不要自己写malloc。练习题除外,呵呵。

《C++内存管理算法和实现》讲了malloc方面的基础知识,里面例子和实验很多,可惜算法分析比较少。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP