第三章 操作系统知识
3.1操作系统的作用
通过资源管理(软硬件资源管理),提高计算机系统的效率改善人机界面,向用户提供友好的工作环境。
操作系统5部分:进程管理、文件管理、存储管理、设备管理、作业管理。
3.2进程管理
3.2.1 进程的概念
进程是程序在一个数据集合上运行的过程,它是系统进行资源分配和调度的一个独立单位。它由程序块、进程控制块(PCB)和数据块三部分组成。
3.2.2 进程状态
- 三态模型
- 五态模型
- 目的:释放进程占用的资源以缓解资源不足
- 原因:终端用户的请求,父进程的请求、OS的需要(如负荷调节、对换等)
3.2.3 PV操作
- 前趋图
- 进程的同步与互斥
互斥:有限资源不能同时分配
同步:等待一些事件的时间节点
- 生产者消费者模型
当生产者的生产效率和消费者的消费效率不一致时怎样解决冲突?PV操作
-
PV操作
-
临界自然:出进程间需要互斥方式对其进行共享的资源,如打印机、磁带机等。
-
临界区:每个进程中访问临界资源的那段代码称为临界区。
-
信号量:是一种特殊的变量。
-
-
PV原语
3.2.4 死锁
概念:进程管理是操作系统的核心,但如果设计不当就会出现死锁的问题。如果一个进程在等待一个不可能发生的事,的进程就死锁了。而如果一个或多个进程产生死锁,就会造成系统死锁。
-
考察:产生死锁的最小系统资源数
m≥n*(w-1)+1
-
死锁的解决:
互斥、保持和等待、不剥夺、环路等待为死锁的必要条件
- 银行家算法(分配资源的原则)
- 当一个进程对资源的最大需求量不超过系统的资源数是可以接纳该进程。、
- 进程可以分期请求资源,但请求的总数不能超过最大需求量。
- 当系统现有的资源不能满足进程尚需资源数时,对进程的请求可以推迟分配,但总能使进程在有限的时间里得到资源。
3.2.5 任务调度
任务调度要解决的问题:
-
何时分配CPU
- 任务调度的时机,5种情形
-
如何分配CPU
- 任务调度方式,不可抢占,可抢占
- 不可抢占调度方式
- 如果一个任务被调度程序选中,就会一直运行下去。
- 直到他因为某种原因(如io操作或任务间的同步)被阻塞了,或者他主动交出cpu的使用权。
- 调度实际中的前三种情况(任务创建、任务运行结束、任务被阻塞),都可以发生调度。第4、5种情况(即发生中断),不会发生调度。
- 可抢占调度方式
- 当一个任务正在运行的时候,调度程序可以比打断他,并安排其他任务执行。
- 调度诗句中的所有五种情况,都可能会发生调度。
- 实时操作系统大都采用可强制的调度方式。
- 不可抢占调度方式
- 任务调度方式,不可抢占,可抢占
-
按什么原则分配CPU
- 任务调度算法,先来先服务、短作业优先、时间片轮转调度、优先级算法
- FIFO:按照任务到达的先后次序进行调度,是不可能抢占的调度方式。
- 平均周转时间差异较大
- SJF: 各个任务开始执行之前是先预计好它的执行时间从中选择用时较短的任务优先执行。
- RR:所有的就绪任务按照先来先服务的原则排成一个队列,在每次调度的时候把处理器分配给队列当中的第一个任务让它去执行一小段时间(时间片)。在这个时间段里任务被阻塞或结束,或者任务的时间片用完了,它会被送到就绪队列的末尾,然后调度器在执行当前队列的第一个任务。
- 公平性:各个就绪任务平均分配使用CPU的时间。
- 活动性:每个就绪任务都能一直保持着活动性。
- 时间片大小要适当选择。
- 优先级算法:给每个任务都设置一个优先级,在任务调度的时候,在所有处于就绪状态的任务中选择优先级最高的任务去执行。
- 优先级反转:高优先级任务需要等待低优先级任务释放资源,低优先级任务有正在等待中优先级任务的现象。
- FIFO:按照任务到达的先后次序进行调度,是不可能抢占的调度方式。
- 调度算法的性能指标
- 任务调度算法,先来先服务、短作业优先、时间片轮转调度、优先级算法
3.2.6 任务间通信
任务之间为了协调工作,需要相互交换数据和控制信息。
分为两种类型:
-
低级通信:只能传递状态和整数值等控制信息,例如信号量机制、异步信号机制。
-
能够传输任意数量的数据,主要有三类:共享内存、消息队列和管道。
-
共享内存:各个任务共享其地址空间中的某些部分,在此区域逗号可以任意读写和使用任意的数据结构把它看成一个通用的缓冲区。
- 使用共享内存来传递数据时,通常需要和任务间的互斥机制结合起来,以免产生竞争条件,确保数据顺利传送。
-
消息传递:任务和任务之间通过发送和接收消息来交换信息。
-
管道:管道是提供非结构化数据交换和实现任务间同步的内核对象。在传统的实现中,管道是单向数据交换设施。
- 管道与消息队列的区别:
- 管道不存储多个消息,它存储的数据是非结构化的字节流;
- 管道中的数据严格地遵循先进先出的顺序;
- 管道支持选择(select)操作,而消息队列不支持。
- 管道与消息队列的区别:
-
3.3 存储管理(内存)
3.3.1 分区存储
- 可变分区分配方法
- 最先匹配法
- 下次匹配法
- 最佳匹配法
-
页式存储
将一个程序分成多个页,将即将运行的程序放到内存中,避免将整个程序同时存入内存过度占用内存的情况。也让运行比内存容量大的程序成为可能。
-
优点:利用率高,碎片小,分配及管理简单
-
缺点:增加了系统开销;可能产生抖动(一段相同的程序不停的进出内存的现象)。
-
段式存储
-
优点:多道程序共享内存,各段程序修改互不影响。
-
缺点:内存利用率低,内存碎片浪费大。
-
段页式存储
- 优点:空间浪费小、存储共享容易、存储保存容易、能动态连接。
- 缺点:由于管理软件的增加,复杂性和开销也随之增加,需要的硬件以及专用的内容也会有所增加,使得执行速度大大下降。
3.3.2 虚拟存储
- 页面置换算法
- 最佳置换算法
- 先进先出置换算法
- 最近最少使用置换算法
- 最近未用置换算法
3.3.3 磁盘结构及调度算法
先来先服务
最短寻道时间优先
扫描算法
循环扫描算法
-
磁盘性能参数
-
非格式化容量
容量=面数x(磁道数/面)x内圆周长x最大位密度
-
格式化容量
容量=面数x(磁道数/面)x(扇区数/道)x(字节数/扇区)
-
-
读取磁盘数据的时间应包括三部分
- 找磁道的时间
- 找块(扇区)的时间,即旋转延迟时间
- 传输时间
3.4 文件管理
3.4.1 文件组织结构
- 逻辑结构
- 流式文件
- 记录式文件
- 物理结构
- 顺序结构(数组)
- 链接结构(链表)
- 索引结构
3.4.2 树形目录结构
3.4.3 文件管理
- 位示图法(文件管理系统查找磁盘空闲块的方法)
3.5 设备管理
虚设备与SPOOLING技术
思考题:
A、B、C、D共用一台打印机X进行资料打印时,很容易出现“打印机正在使用”,如何处理该问题?