操作系统3.2.1,考研掌握这些就够了

3.2.1 内存管理:连续分配管理方式

连续分配管理方式思维导图:

连续分配管理方式

连续分配管理方式即为进程分配的内存空间必须是连续的

单一连续分配

  • 内存分为系统区和用户区
  • 系统将用户区整体分配给一个单一进程使用
  • 只支持单道程序
  • 无外部碎片,有内部碎片

内部碎片指的是程序不能占满分配给它的分区的所有空间

固定分区分配

  • 内存用户空间分为若干固定大小的分区,每个分区只能装一道作业
  • 支持多道程序
  • 无外部碎片,有内部碎片
  • 两种分区方式:分区大小相等、分区大小不等

动态分区分配(可变分区分配)

动态分区分配思维导图:

动态分区分配(可变分区分配)

只有可变分区方式不会产生内部碎片

  • 支持多道程序,在进程装入内存时根据进程的大小动态建立分区
  • 无内部碎片,有外部碎片
  • 外部碎片可用‘紧凑技术’来解决

回收内存分区时可能遇到四种情况

  • 回收区后有相邻的空闲分区
  • 回收区前有相邻的空闲分区
  • 回收区前后都有相邻的空闲分区
  • 回收区前后都没有相邻的空闲分区

需要的数据结构

  • 空闲分区表/空闲分区链
  • 分区号
  • 分区大小
  • 分区起始地址
  • 分区状态:是否占用

分配算法
不论何种方法,为了减少外部碎片往往造成大分区的缺失

首次适应算法
  • 空闲分区以地址升序排序
  • 从头到尾寻找第一个满足条件的分区
  • 综合看性能最好
循环首次适应算法(邻近适应算法)
  • 空闲分区按照地址升序排序,每次从上一次的位置向后查找
  • 会使高地址大分区尽快用完
最佳适应算法
  • 空闲分区按分区大小递增排列
  • 会留下大分区,也会产生很多外部碎片
  • 算法开销大,回收分区后都要重新排序
最坏适应算法
  • 空闲分区按分区大小递减排列
  • 大分区容易用完,不利于大进程,算法开销大
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

毓见美好.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值