连续内存分配

连续内存分配和内存碎片

连续内存分配:给进程分配一块不小于指定大小的连续的物理内存区域

内存碎片:空间内存不能被利用

      外部碎片:分配单元之间的未被使用内存

      内部碎片:分配单元内部的未被使用内存,取决于分配单元大小是否要取整

 

动态分区分配

当程序被加载执行时,分配一个进程指定大小可变的分区(块、内存块),分区的地址是连续的

操作系统需要维护的数据结构:

1 所有进程的已分配分区

2 空闲分区(Empty-blocks)

动态分区分配策略:

1 首次适应次略

思路:分配n个字节,使用第一个可用的空间比n大的空闲分区,空间分区列表按地址顺序排序,分配过程中,搜索第一个合适的分区,释放分区时,检查是否可与临近的空闲分区合并。

优点:简单、在高地址空间有大块的空闲分区

缺点:容易产生外部碎片、分配大块是较慢

2 最佳适应策略

思路:分配n个字节,查找并使用不小于n的最小空闲块

思路:空闲分区列表升序排序,释放时,查找并且合并临近的空闲分区(如果找到)

优点:大部分分配的尺寸较小是、可避免大的空闲分区被拆分、可减小外部碎片的大小、相对简单

缺点:会有外碎片、释放分区较复杂、容易产生无法利用的小碎片

3 最差适应策略

思路:分配n个字节,使用尺寸不小于n的最大空闲分区,空闲分区列表按降序排序,分配时,选最大的分区,释放时,检查是否可与临近的空闲分区合并,进行可能的合并并调整空闲分区列表顺序。

优点:中等大小的分配较多时、可以避免出现太多的碎片

缺点:释放分区较慢、会产生外部碎片、容易破坏大的空闲碎片,因此后续难以分配大的分区。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值