覆盖与交换

一、覆盖技术

在程序的内存大小大于实际(物理)内存的大小时,就需要覆盖技术来解决这个问题

1.概念

覆盖技术的思想:将程序分为多个段(多个模块)。

常用的段常驻内存,不常用的段在需要时调入内存。

内存中分为一个“固定区”和若干个“覆盖区”。

需要常驻内存的段放在“固定区”中,调入后就不再调出(除非运行结束)

不常用的段放在“覆盖区”,需要用到时调入内存,用不到时调出内存

 

对上面这个程序:

物理内存:

程序x的固定区A(8K)

程序x的覆盖区0(10K)

程序x的覆盖区1(12K)

按照自身逻辑结构,让那些不可能同时被访问的程序段共享同一个覆盖区

2.特点

必须由程序员声明覆盖结构,操作系统完成自动覆盖。

缺点:对用户不透明,增加了用户编程负担。

覆盖技术只用于早期的操作系统中,现在已成为历史。

二、交换技术

1.概念

交换(对换)技术的设计思想:内存空间紧张时,系统将内存中某些进程暂时换出外存,把外存中某些已具备运行条件的进程换入内存(进程在内存与磁盘间动态调度)

中级调度(内存调度):就是要决定将哪个处于挂起状态的进程重新调入内存。

外存——>内存

挂起队列在外存里面

暂时换出外存等待的进程状态为挂起状态(挂起态,suspend)

挂起态又可以进一步细分为就绪挂起、阻塞挂起两种状态

2.特点

问题

1.应该在外存(磁盘)的什么位置保存被换出的进程?

2.什么时候应该交换?

3.应该换出哪些进程?

解决方法

1.具有对换功能的操作系统中,通常把磁盘空间分为文件区和对换区两部分。

文件区:

主要用于存放文件,主要追求存储空间的利用率,因此对文件区空间的管理采用离散分配方式;

对换区:

存储空间只占磁盘空间的小部分,被换出的进程数据就存放在对换区。由于对换的速度直接影响到系统的整体速度,因此对换区空间的管理主要追求换入换出速度,因此通常对换区采用连续分配方式。

对换区的I/O速度比文件区的更快,而文件区的大小比对换区大得多

2.交换通常在许多进程运行且内存吃紧时进行,而系统负荷降低就暂停。

例如:在发现许多进程运行时经常发生缺页,就说明内存紧张,此时可以换出一些进程;如果缺页率明显下降,就可以暂停换出。

3.可优先换出阻塞进程;可换出优先级低的进程;

为了防止优先级低的进程在被调入内存后很快又被换出,有的系统还会考虑进程在内存的驻留时间...

(注意:PCB会常驻内存,不会被换出外存)

三、总结

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值