操作系统理论知识9

这篇博客详细介绍了操作系统中存储器管理的相关知识,包括程序装入和连接的三种方式(绝对装入、静态重定位装入、动态运行时重定位装入)、地址映射、连续分配存储管理方式、分页和分段存储管理方式,以及虚拟存储器的工作原理和页面置换算法。文章深入探讨了地址从逻辑地址到物理地址的转换,以及各种存储管理方式的优缺点和应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我的操作系统笔记

第四章 存储器管理

存储器部件

在这里插入图片描述

主存
保存进程运行时的程序和数据
寄存器
速度最快,价格昂贵容量不大,一般以字为单位,只要存放指令一次操作的数据就够了 。
高速缓存
速度快、存放部分内存数据、硬件自动处理
磁盘缓存
内存的一部分,将频繁使用的一部分磁盘数据信息预读入在磁盘缓存,减少磁盘读写时间。

存储器管理

内存管理:
存储器资源的分配和回收
地址变换(逻辑地址与物理地址的对应关系维护)
存储共享和保护
虚拟存储的调度算法

一、程序的装入和连接

程序进内存的一般过程:
1、编译compiler:编译程序:将用户源代码编译成若干个目标模块。
2、链接link:链接程序:将形成的一组目标模块,及它们需要的库函数链接在一起,形成一个完整的装入模块。
3、装入load:由装入程序将装入模块装入内存,构造PCB,形成进程,开始运行(使用物理地址)。
在这里插入图片描述

地址
逻辑地址(相对地址,虚地址)

用户的程序经过汇编或编译后形成目标代码,目标代码中的指令地址是相对地址。
一般首地址为0,其余指令中的地址都相对于首地址来编址。
不能用逻辑地址在内存中读取信息

物理地址(绝对地址,实地址)

内存中存储单元的地址。
物理地址可直接寻址被执行。

地址映射:

将用户程序中的逻辑地址转换为运行时由机器直接寻址的内存物理地址的过程。
即:用户的第10字节处的指令在内存的第多少地址上。

程序链接、装入过程围绕着地址的处理

程序装入中的地址处理
1、绝对装入(逻辑地址=物理地址)(absolute loading)

在这里插入图片描述
编译程序生成的“目标代码”就是”装入模块” ,逻辑地址直接从某个地址R处增长,装入模块直接装入内存地址R处

物理地址一般由编译或汇编程序给出或由程序员赋予(要求程序员熟悉内存使用情况)

优点:装入过程简单。不需任何地址变换,程序中的逻辑地址与实际内存物理地址完全相同。
缺点:过于依赖硬件结构, 只适用早期针对硬件直接编程、单道环境下。

2、静态重定位装入(relocatable loading mode)

现在程序装入一般都要从逻辑地址映射到物理地址

重定位:把目标程序中的指令和数据的逻辑地址变成内存中的物理地址的地址变换过程。
在这里插入图片描述
地址映射在程序执行之前进行,重定位后物理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值