基本分页存储管理方式
比较连续分配方式:
- 作业逻辑地址空间有M大,就需要向内存申请一个M大的连续区域。
- 分页的目的是更细粒度的处理空间,减少粗放管理的浪费或开销问题。
离散分配内存:
- 作业规定大小划分成小份;内存也按同样大小划分成小份
- 作业的任一小份可分散放入内存任意未使用的小份
分页方式下,内存的使用率高,浪费少。但不是绝对没有碎片(进程的最后一页不总是能占满一个物理块)
1)页面的概念
内存划分成多个小单元,每个单元K大小,称(物理)块。作业也按K单位大小划分成片,称为页面。
① 物理划分块的大小 = 逻辑划分的页的大小
②页面大小要适中。
- 太大,(最后一页)内碎片增大,类似连续分配的问题。
- 太小的话,页面碎片总空间虽然小,提高了利用率,但每个进程的页面数量较多,页表过长,反而又增加了空间使用。
2)页表的概念
- 为了找到被离散分配到内存中的作业,记录每个作业各页映射到哪个物理块,形成的页面映射表,简称页表。
- 每个作业有自己的页表
- 页表的作用:
页号到物理块号的地址映射
- 要找到作业A
关键是找到页表(PCB)
根据页表找物理块
若内存和作业均按1K大小划分块或页,一个4K大的作业可如下图般分配: