美文网首页
【转】内存碎片的产生

【转】内存碎片的产生

作者: 离人歌 | 来源:发表于2017-07-05 17:42 被阅读165次

内存碎片的产生:
内存分配有静态分配和动态分配两种
静态分配在程序编译链接时分配的大小和使用寿命就已经确定,而应用上要求操作系统可以提供给进程运行时申请和释放任意大小内存的功能,这就是内存的动态分配。 因此动态分配将不可避免会产生内存碎片的问题,那么什么是内存碎片?内存碎片即“碎片的内存”描述一个系统中所有不可用的空闲内存,这些碎片之所以不能被使用,是因为负责动态分配内存的分配算法使得这些空闲的内存无法使用,这一问题的发生,原因在于这些空闲内存以小且不连续方式出现在不同的位置。因此这个问题的或大或小取决于内存管理算法的实现上。
为什么会产生这些小且不连续的空闲内存碎片呢?
实际上这些空闲内存碎片存在的方式有两种:a.内部碎片 b.外部碎片
内部碎片的产生 :因为所有的内存分配必须起始于可被 4、8 或 16 整除(视处理器体系结构而定)的地址或者因为MMU的分页机制的限制,决定内存分配算法仅能把预定大小的内存块分配给客户。假设当某个客户请求一个 43 字节的内存块时,因为没有适合大小的内存,所以它可能会获得 44字节、48字节等稍大一点的字节,因此由所需大小四舍五入而产生的多余空间就叫内部碎片。
外部碎片的产生 : 频繁的分配与回收物理页面会导致大量的、连续且小的页面块夹杂在已分配的页面中间,就会产生外部碎片。假设有一块一共有100个单位的连续空闲内存空间,范围是099。如果你从中申请一块内存,如10个单位,那么申请出来的内存块就为09区间。这时候你继续申请一块内存,比如说5个单位大,第二块得到的内存块就应该为1014区间。如果你把第一块内存块释放,然后再申请一块大于10个单位的内存块,比如说20个单位。因为刚被释放的内存块不能满足新的请求,所以只能从15开始分配出20个单位的内存块。现在整个内存空间的状态是09空闲,1014被占用,1524被占用,2599空闲。其中09就是一个内存碎片了。如果1014一直被占用,而以后申请的空间都大于10个单位,那么09就永远用不上了,变成外部碎片。

相关文章

  • 【转】内存碎片的产生

    内存碎片的产生:内存分配有静态分配和动态分配两种 静态分配在程序编译链接时分配的大小和使用寿命就已经确...

  • Linux内存管理-内存碎片的终极解决方案

    内存碎片问题 频繁地请求和释放不同大小的内存,必然导致内存碎片问题的产生,结果就是当再次要求分配连续的内存时,即使...

  • 分析高效内存池的实现方式

    1. 内存池的目的 提高程序效率 减少运行时间 避免内存碎片 为什么会产生内存碎片?1.内部碎片是采用固定大小的内...

  • [转]Redis内存碎片率

    一、 内存碎片率 mem_fragmentation_ratio = used_memory_rss / used...

  • 如何避免内存碎片

    频繁地请求和释放不同大小的内存,必然导致内存碎片问题的产生,结果就是当再次要求分配连续的内存时,即使整体内存是足够...

  • 如何避免内存碎片

    频繁地请求和释放不同大小的内存,必然导致内存碎片问题的产生,结果就是当再次要求分配连续的内存时,即使整体内存是足够...

  • 伙伴算法和slab算法

    0. 内存管理问题 内存碎片太小和管理内存碎片的效率问题 内存碎片:回收内存时,将内存块放入free链表中。因内存...

  • 存储器管理

    你怎么理解操作系统里的内存碎片,有什么解决办法? 考察点:内存碎片参考回答: 内存碎片分为:内部碎片和外部碎片。 ...

  • C#取出字典里所有的值

    1、Foreach foreach简单,但是在使用的时候会产生大量的垃圾内存碎片,不及时清理会使内存激增。在Uni...

  • 垃圾收集算法

    1、标记-清除算法容易产生大量不连续的内存碎片2、复制算法将内存分为Eden控件和两个survivor控件,每次使...

网友评论

      本文标题:【转】内存碎片的产生

      本文链接:https://www.haomeiwen.com/subject/igiqhxtx.html