内存碎片/内存空洞
2017-06-08 15:25
1926 查看
内存碎片/内存空洞
内存碎片:程序长时间运行后,由于不停的malloc/free操作,尽管不存在内存泄露,但程序所占用的内存空间越来越大,有时候还会导致malloc申请失败,这就是由于内存碎片所导致。
产生原因:
非mmap申请的内存,其释放,只能从堆顶开始。中间部分的内存即使通过free释放掉,但仍然是被当前程序所占用,并未彻底释放到堆中,无法供其他程序使用。只有堆顶部分内存也释放后,这片区域才能融合成一大片空间。
解决方案:
此问题没有最终的完美的解决方案。
尽可能多采用内存空间的复用,减少频繁申请大量小的内存块的操作。
对程序所需要的动态内存进行统一规划。把需要长时间占用的内存的申请操作,在程序刚启动后初始化时进行,把不需要长时间占用的内存的申请操作,后执行。这样堆顶可以尽早释放。
但要注意的是,内存分配不一定是顺序的,即后来申请的内存地址不一定就比原来的内存地址大,可能用了之前释放的一片区域。
通过动态内存管理模块封装内存的申请和释放。
http://blog.csdn.net/kickxxx/article/details/9212317
http://www.cnblogs.com/wang-can/p/3345580.html
http://www.cnblogs.com/zhaoyl/p/3820852.html
http://www.cnblogs.com/youxin/p/3693252.html
http://www.xuebuyuan.com/1559542.html
http://blog.csdn.net/fengyelengfeng/article/details/45027471
相关文章推荐
- 内存碎片
- 又一个简单而强大的单片机内存管理器-不带内存碎片整理
- The Dangers of the Large Object Heap(转载,LOH内存碎片情景重现)
- 完美删除vector的“内存空洞”
- Linux伙伴系统算法--防止内存碎片的产生
- 内存的反碎片技术-伙伴系统&内存分类
- vector删除元素与清除内存空洞
- 内存碎片产生的原因
- Redis采用不同内存分配器碎片率对比
- malloc、free与内存碎片
- linux内存碎片的概念
- 防止产生内存碎片
- vector删除元素与清除内存空洞
- 内存空洞
- 关于内存空洞的一个解释
- 关于结构体中的内存空洞、sizeof(struct)以及编译器优化的见解
- oracle内存碎片
- [ASM/C/C++]内存碎片处理技术
- malloc、free与内存碎片
- malloc、free与内存碎片