操作系统笔记 第四章 存储器管理

本文详细介绍了操作系统的存储器管理,包括程序的装入和链接的地址处理、连续分配方式及其产生的碎片问题、基本的分页存储管理方式以及分段存储管理方式,强调了分页和分段的主要区别,并探讨了信息共享和段页式存储管理。
摘要由CSDN通过智能技术生成

存储部件的层次

在这里插入图片描述

1、程序的装入和链接

程序进内存的一般过程:

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

在这里插入图片描述

1)地址的概念

逻辑地址(相对地址,虚地址)
	用户的程序经过汇编或编译后形成目标代码,目标代码中的指令地址是相对地址。

	- 一般首地址为0,其余指令中的地址都相对于首地址来编址。

	- 不能用逻辑地址在内存中读取信息

物理地址(绝对地址,实地址)
	
	内存中存储单元的地址。
	
	物理地址可直接寻址被执行。
地址映射:
	将用户程序中的逻辑地址转换为运行时由机器直接寻址的内存物理地址的过程。
	
	即:用户的第10字节处的指令在内存的第多少地址上。

2)程序装入中的地址处理

逻辑地址  ======   物理地址:
① 绝对装入方式(absolute loading)

逻辑地址 重定位 物理地址:
② 静态可重定位装入方式(relocatable loading mode)
③ 动态运行时(重定位)装入方式(dynamic run-time loading) 

重定位:把目标程序中的指令和数据的逻辑地址变成内存中的物理地址的地址变换过程

3)不同的程序链接方式

装入是使用内存的开始,但链接的不同会使内存的使用有差别:

根据链接时间的不同,分成三种:
	① 静态链接:装入运行前将多个目标模块及所需库函数链接成一个整体,以后不再拆开。
	② 装入时动态链接:装入内存时,边装入边链
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值