计算机操作系统笔记04

本文详细介绍了操作系统中程序的装入、链接过程,包括地址概念、静态装入、动态运行时重定位。接着讨论了连续分配存储管理方式,如单一连续分配、固定分区分配及其优缺点。重点讲述了分页和分段存储管理,包括页面概念、地址变换、快表以及分页与分段的主要区别。最后,探讨了虚拟存储器的基本概念、实现和特征,以及请求分页存储管理方式和页面置换算法的重要性。
摘要由CSDN通过智能技术生成

第4章 存储器管理

4-1 程序的装入和链接

程序进内存的一般过程:

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

1、地址的概念

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

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

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

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

 

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

1)绝对装入(逻辑地址=物理地址)

编译程序生成的“目标代码”就是”装入模块” ,逻辑地址直接从某个地址R处增长,装入模块直接装入内存地址R处。

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

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

 

 

2)静态重定位装入

静态可重定位装入方式
地址映射在程序执行之前进行,重定位后物理地址不再改变。
可由专门设计的重定位装配程序完成(软):装入时根据所定位的内存地址去修改每个逻辑地址,添加相应偏移量,重定位为物理地址。

  • 优点:不需硬件支持,可以装入有限的多道程序
  • 缺点:软件装入一次完成,一个程序通常需要占用连续的内存空间,程序装入内存后不能移动。也不易实现共享。

3)动态运行时重定位装入

动态运行时(重定位)装入方式(dynamic run-time loading)
实际运行中往往会需要程序在内存中的各位置移动,即经常需要重定位到不同的物理地址上。
这种运行时移动程序要求地址变换要快速,实现时一般依靠硬件地址变换机构——一个重定位寄存器。
程序装入内存时,可多次重定位到不同位置。
且可以不立即把装入模块中的相对地址转换为绝对地址,而是把这种地址转换推迟到程序真正要执行时才进行。
更适用于部分装入

 

3、不同的程序链接装入方式(使用内存的时机)

1)静态链接

① 静态链接:
装入运行前,生成可执行文件时进行的。
将多个目标模块及所需库函数链接成一个整体,以后不再拆开。

2)装入时链接

② 装入时动态链接
由一个目标模块开始装入,若又涉及外部模块调用事件,装入程序再找出相应的外部目标模块,并将它装入内存,还要修改目标模块中的相对地址。
比静态链接好在哪里?
(1) 静态链接好的程序,修改部分模块后,需重新链接成可装入程序。动态方式则便于修改和更新。
(2) 便于实现共享。静态的N个程序都需要一个模块时,需要进行N次拷贝。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值