段页式存储管理
分页式管理提高了内存的利用率,分段式管理方便了用户的使用。结合两者的优点,段页式管理内存的方式由此产生。
内存被分成若干个大小相同的页,比如现在我们用的每个页的大小一般是4k大小。我们程序每个段(代码段,数据段
堆栈段)又被分成多个页,这些页的内存地址不一定连续,这时候我们需要一个段表来记录不同的段划分的页分配到
哪个页了。每个页对应的物理地址也需要一个页表来记录。
段页式的物理结构是:
地址变化:
首先我们对物理地址切分,前2位或者3位得到队形的段号,然后去查看是否超过分配的段,若没超过,则与段表
寄存器的相加,根据段表得到页表的起始地址,然后与段内页号相加得到页表的首地址,得到的页表的地址与实际
地址d拼接,得到实际的物理地址。
整个过程需要三次访问主存,访问段表->访问页表->访问物理地址。
对于用户来说,操作系统的内存管理方式到底是段式存储,页式存储,还是段页式存储是透明的。操作系统会根据
实际的进程来确定到底以哪种分配方式来分配内存。所以编写操作系统的人才是真正的大佬,我们这些程序员还是
有差距,哈哈。