操作系统学习笔记——进程的状态

1.    为什么要分开就绪和阻塞状态

       答:因为就绪态只需要等待处理机,而阻塞态可能在等待输入输出,即使分配给处理机也是徒劳,所以两状态图不妥。对于调度进程,只需要等待就绪队列里的进程,因为阻塞状态可以转换到就绪队列里去。

 

2.    进程五状态

 

1)       新状态:进程已经创建,但未被OS接纳为可执行进程。(还没有申请到相应的资源)。

2)       就绪态:进程做好了准备,准备执行(只等待处理机)。

3)       执行状态:该进程正在执行(单处理机,某一时刻仅一个进程占用处理机)。

4)       阻塞状态:等待某事件发生才能执行,如等待I/O完成。

5)       终止状态.

 

3.    问题:多个进程竞争内存资源

l  内存资源紧张

l  无就绪队列,处理机空闲:I/O速度比处理机速度慢的多,可能出现全部进程阻塞等待I/O。

解决方法

l  交换技术:换出一部分暂时不能运行的进程(阻塞进程)到外存(只换出程序和数据,PCB不换出去),以腾出内存空间,可以调用新进程来执行。

l  虚拟存储技术:每个进程只能装入一部分程序和数据

 

4.      挂起:进程被交换到外存,状态变为挂起状态

4.1   进程挂起的原因(p91)

l  进程全部阻塞,处理机空闲。

l  系统负荷过重,内存空间紧张。(让其他进程先执行完)

l  操作系统的需要。操作系统可能需要挂起后台进程或一些服务进程,或者某些可能导致故障的进程。

l  终端用户请求。

l  父进程的需求。

4.2  挂起进程的特征

l  不能立即执行

l  可能是等待某事件发生,若是,则阻塞条件独立于挂起条件,即使阻塞事件发生,该进程也不能执行。

n  阻塞和挂起没有联系。

n  如果A进程现在要求输入数据,此时A进程属于阻塞状态,在选择挂起进程的时候,可能先选择阻塞进程(A进程),此时A进程挂起,正在输入数据,输入到内存缓冲区内。当数据输完了,向处理机发送命令数据已经输入完成,阻塞事件解除,但实际上还是挂起,所以仍是挂起态。

l  使之挂起的进程为:自身、父进程、OS。

l  只有挂起它的进程才能使之由挂起状态转换为其他状态。

 

4.3  阻塞与挂起

l  进程是否等待时间:阻塞与否。

l  进程是否被换出内存:挂起与否。

 

4.4  四种状态组合

l  就绪:进程在内存,准备执行。

l  阻塞:进程在内存,等待事件。

l  就绪/挂起:进程在外存,只要调入内存即可执行。

l  阻塞/挂起:进程在外存,等待事件。

 

4.5  处理机可调度执行的进程有两种

l  新创建的进程

l  或换入一个以前挂起的进程

通常为避免增加系统负载,系统会换入一个以前挂起的进程执行。

 

4.6  具有挂起状态的进程状态转换


l  阻塞 → 阻塞/挂起:OS通常将阻塞进程换出,以腾出内存空间

l  阻塞/挂起→ 就绪/挂起:当阻塞/挂起进程等待的事件发生时,可以将其转换为就绪/挂起。

l  就绪/挂起→ 就绪:OS需要调入一个进程执行。

l  就绪 → 就绪/挂起:一般,OS挂起阻塞进程。但是有时也会挂起就绪进程,释放足够的内存空间。

l  新 → 就绪/挂起(新→ 就绪):新进程创建后,可以插入到就绪队列或就绪,挂起队列,若无足够的内存分配给新进程,则需要新→ 就绪/挂起。

l  。。。

实现了如下四种调度算法的模拟: (1)时间片轮转调度 (2)优先数调度 (3)最短进程优先 (4)最短剩余时间优先 模拟过程使用了JProgressBar作为进程状态条,更为直观地观察到每个进程的执行状态。 程序用户说明: 1、在上图标号1处输入要创建随机进程的个数,仅可输入正数,非正数会有相关提示。然后点击标号2处的“创建进程”按钮,随进创建的进程显示在程序界面的中央窗口,如标号3所示。 2、创建好随机进程后,在标号4的单选框选择将要模拟执行的调度算法,然后点击标号5处的“开始模拟”,程序开始执行。标号3的列表会显示相应的调度变化。 3、模拟过程中,可以继续添加新的进程,操作同上。 4、 一个算法模拟执行完毕之后,可以点击标号6的“复位”按钮,可以重置列表的内容为程序模拟运行前的内容。复位成功后,可以继续选择其他调度算法进行模拟。 5、标号7显示为程序模拟过程中的时间,从1秒开始累计。 6、点击标号8的“清空”按钮,可以清空类别的进程,以便程序的下次执行。 题目要求: 题目四 单处理器系统的进程调度 一 、 课 程 设 计 目 的 1. 加深对进程概念的理解, 明确进程和程序的区别。 2. 深入了解系统如何组织进程、 创建进程。 3. 进一步认识如何实现处理器调度。 二 、 课 程 设 计 内 容 编写程序完成单处理器系统中的进程调度, 要求实现时间片轮转、 优先数、 最短进程优 先和最短剩余时间优先四种调度算法。 实验具体包括: 首先确定进程控制块的内容, 进程控 制块的组成方式; 然后完成进程创建原语和进程调度原语; 最后编写主函数对所作工作进行 测试。 模拟程序只对你所设置的“ 虚拟 PCB” 进行相应的调度模拟操作, 即每发生“ 调度” 时, 显示当前运行进程的“ 进程标识符”、“ 优先数”、“ 剩余运行时间” 等, 而不需要对系 统中真正的 PCB 等数据进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值