免费注册 查看新帖 |

Chinaunix

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

[C++] malloc内存碎片问题 [复制链接]

论坛徽章:
1
2015亚冠之浦和红钻
日期:2015-05-26 14:37:09
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-05-25 17:59 |只看该作者 |倒序浏览
我们通常所说的频繁malloc内存,会产生内存碎片,这里所说的内存碎片,是指物理内存不足的内存碎片,还是虚拟内存地址空间的不足的内存碎片?




因为在linux系统中,我们都是用虚拟地址空间和物理地址相对应,malloc分配的也是虚拟地址空间,那么频繁malloc为什么会产生内存碎片??

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
2 [报告]
发表于 2015-05-25 21:47 |只看该作者
是虚拟地址空间的。
被分配掉的区间之间的小块太小无法被利用,就是碎片

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
3 [报告]
发表于 2015-05-26 09:13 |只看该作者
用 tcmalloc, jemalloc

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
4 [报告]
发表于 2015-05-26 09:13 |只看该作者
一般Malloc用的伙伴分配算法吧。 不然无法保证频繁分配释放。
malloc分配的“碎片”正是虚拟空间的碎片。虚拟空间也是有限的啊。

论坛徽章:
1
射手座
日期:2013-08-21 13:11:46
5 [报告]
发表于 2015-05-26 11:19 |只看该作者
cokeboL 发表于 2015-05-26 09:13
用 tcmalloc, jemalloc


就用这俩,其实glibc的ptmalloc也还行,没有你想想的那么差

论坛徽章:
1
2015亚冠之浦和红钻
日期:2015-05-26 14:37:09
6 [报告]
发表于 2015-05-26 11:28 |只看该作者
回复 2# hellioncu

原来是这样啊,那如果我们采用的是64位的虚拟内存地址,那就没有这个所谓的虚拟空间地址不够的问题了啊。。



另外一个问题,我们linux系统都是采用分页的机制, 一段连续的虚拟内存空间地址,对应的物理内存是不连续的,以页为单位,是不是可以说在这种方式之下,物理内存意义上的外部碎片不存在呀?因为每个分页都是4k,我们不需要获得连续的物理内存,只要有足够大的物理内存空间就行。

一句话:由于采用分页机制,物理内存角度上的外部碎片不存在。可以这么理解吗?



同时操作系统的伙伴算法,可以尽力保持连续的物理内存。但是我们都采用分页机制了,根本不要求物理内存连续,为什么还要操作系统采用伙伴系统,保持连续的物理内存呢??





论坛徽章:
1
2015亚冠之浦和红钻
日期:2015-05-26 14:37:09
7 [报告]
发表于 2015-05-26 11:31 |只看该作者
回复 4# folklore


我们平常使用的ptmalloc怎么会采用伙伴系统呢?伙伴系统是对应linux内核的内存管理算法。。ptmalloc的实现,不是采用freelist的方法嘛。。

我也觉得这里所说的内存碎片是指虚拟地址空间的。如果是物理内存的碎片,难以解释。除非我们的物理内存空间要求连续,这样说malloc频繁使用,会产生物理内存的碎片也可以说的通

论坛徽章:
1
2015亚冠之浦和红钻
日期:2015-05-26 14:37:09
8 [报告]
发表于 2015-05-26 14:33 |只看该作者
回复 3# cokeboL


我问的是内存碎片的概念。还要就是应用层的内存管理,和操作系统的内存管理的问题。。

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
9 [报告]
发表于 2015-05-26 20:09 |只看该作者
回复 8# kkshaq


举例子最简单了,比如:

你共有内存20字节,你给a、b、c、d、e各分了4字节,它们5个地址连续
然后你释放了a、c、e
这样你的前4个中间4个和最后4个字节都是可用的内存
现在你想分配一个8字节,虽然总量大于8但是每块都比8小,这就叫碎片,碎片不可用了

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
10 [报告]
发表于 2015-05-26 20:16 |只看该作者
本帖最后由 cokeboL 于 2015-05-26 20:16 编辑

回复 5# egmkang


   恩恩,我是看这个,就不自己测了,省心http://www.360doc.com/content/13/0915/09/8363527_314549525.shtml
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP