malloc、free与内存碎片
2011-01-14 00:03
274 查看
malloc和free大量使用后回造成内存碎片,那么这种碎片形成的机理是什么?如果机理是申请的内存空间大小(太小)所形成的,那么申请多大的区域能够最大限度的避免内存碎片呢(这里的避免不是绝对的避免,只是一种概率)?
内存碎片一般是由于空闲的连续空间比要申请的空间小,导致这些小内存块不能被利用.产生内存碎片的方法很简单,举个例:
假设有一块一共有100个单位的连续空闲内存空间,范围是0~99.如果你从中申请一块内存,如10个单位,那么申请出来的内存块就为0~9区间.这时继续申请一块内存,比如说5个单位大,第二块得到的内存块就应该为10~14区间.如果把第一块内存块释放,然后再申请一块大于10个单位的内存块,比如说20个单位.因为刚被释放的内存块不能满足新的请求,所以只能从15开始分配出20个单位的内存块.现在整个内存空间的状态是0~9空闲,10~14被占用,15~24被占用,25~99空闲。其中0~9就是一个内存碎片了.如果10~14一直被占用,而以后申请的空间都大于10个单位,那么0~9就永远用不上了,造成内存浪费.
内存碎片一般是由于空闲的连续空间比要申请的空间小,导致这些小内存块不能被利用.产生内存碎片的方法很简单,举个例:
假设有一块一共有100个单位的连续空闲内存空间,范围是0~99.如果你从中申请一块内存,如10个单位,那么申请出来的内存块就为0~9区间.这时继续申请一块内存,比如说5个单位大,第二块得到的内存块就应该为10~14区间.如果把第一块内存块释放,然后再申请一块大于10个单位的内存块,比如说20个单位.因为刚被释放的内存块不能满足新的请求,所以只能从15开始分配出20个单位的内存块.现在整个内存空间的状态是0~9空闲,10~14被占用,15~24被占用,25~99空闲。其中0~9就是一个内存碎片了.如果10~14一直被占用,而以后申请的空间都大于10个单位,那么0~9就永远用不上了,造成内存浪费.
相关文章推荐
- malloc、free与内存碎片
- malloc、free与内存碎片
- malloc,free动态申请释放内存机制
- 内存分配方式,堆区,栈区,new/delete/malloc/free
- C/C++ 内存分配方式,堆区,栈区,new/delete/malloc/free
- 内存分配方式,堆区,栈区,new/delete/malloc/free
- FFmpeg源代码简单分析:内存的分配和释放(av_malloc()、av_free()等)
- malloc与free对被操作内存的影响
- C语言中多维数组的内存分配和释放(malloc与free)的方法
- 【转载】malloc内存分配与free内存释放的原理
- C/C++ 内存分配方式,堆区,栈区,new/delete/malloc/free
- 内存储器管理概述、内存分配与释放、地址映射机制(mm_struct, vm_area_struct)、malloc/free 的实现
- new/delete和malloc/free的区别,sizeof的理解和struct内存对齐
- ffmpeg的内存的分配和释放av_malloc()、av_free()的函数
- malloc & 内存碎片 & 细节
- malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存
- FFmpeg源代码简单分析:内存的分配和释放(av_malloc()、av_free()等)
- FFmpeg源代码简单分析:内存的分配和释放(av_malloc()、av_free()等)
- malloc和free(1)——malloc()申请内存得到指针,指针没有改变,用free()释放内存,不会报错
- 尽量使用new/delete操作符,而不是malloc/free来分配内存-------Effective C++学习笔记