可抢占的优先级调度算法算例:CPU利用率

某多道程序设计系统配有一台处理器和两台外设IO1、IO2,现有3个优先级由高到低的作业J1、J2和J3都已装入了主存,它们使用资源的先后顺序和占用时间分别是:

J1:IO2(30 ms),CPU(10ms),IO1(30ms),CPU(10ms).
J2:IO1(20 ms),CPU(20ms),IO2(40ms)
J3:CPU(30ms),IO1(20ms)

处理器调度采用可抢占的优先数算法,忽略其他辅助操作时间,回答下列问题:
(1)分别计算作业J1、J2和J3从开始到完成所用的时间。
(2)3个作业全部完成时CPU的利用率。
(3)3个作业全部完成时外设IO1的利用率。

[分析]
如前说述,本题在多道系统中的三个进程不仅要竞争使用处理机,而且还要竞争使用外设,这使得进程之间的关系更加复杂。另一方面,本题为了突出进程对CPU和外设的使用,弱化了作业调度的处理,因此题目中已假设这三个进程都已经装入主存,从这一点看,又降低了本题的难度。分析过程如图4.2所示(图中水平箭头表示实际执行过程,水平虚线表示等待过程)。

进程示意图

解答:
(1)由图4.2可知:
J1从开始到完成的时间是0~80ms
J2从开始到完成的时间是0~90ms
J3从开始到完成的时间是0~90ms

(2)三个作业全部完成时CPU的利用率是:
Up = (20 + 10 + 10 + 10 + 10 + 10) / 90 = 70 / 90 = 77.8 %

(3)三个作业全部完成时外设IO1的利用率是:
Uio1 = (20 + 30 + 20) / 90 = 70 / 90 = 77.8 %

  • 11
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
抢占优先级调度算法是一种基于进程优先级调度法,当CPU资源被一个进程占用后,该进程将一直运行直到完成或者阻塞。在实验中,我们可以通过设置不同的进程优先级,观察不同优先级进程的执行情况,以及系统的性能表现。 实验步骤如下: 1. 编写一个模拟调度程序,模拟非抢占优先级调度算法。 2. 创建多个进程,并设置不同的优先级,用于模拟不同的进程执行情况。 3. 运行调度程序,观察不同优先级进程的执行情况,以及系统的性能表现,包括CPU利用率、响应时间、吞吐量等。 4. 对比不同优先级进程的执行情况和系统的性能表现,分析非抢占优先级调度算法的优缺点,以及适用场景。 实验分析如下: 1. 优点: 非抢占优先级调度算法简单易懂,易于实现,适用于实时系统和低负载情况下的桌面应用等场景。 2. 缺点: 高优先级进程会优先执行,低优先级进程可能长时间得不到CPU资源,导致低优先级进程被饿死。 在高负载情况下,非抢占优先级调度算法会导致低优先级进程长时间得不到CPU资源,影响系统的性能表现。 3. 适用场景: 非抢占优先级调度算法适用于实时系统和低负载情况下的桌面应用等场景,特别是对于实时性要求较高的应用,如航空控制系统、医疗设备等。 需要注意的是,在实际应用中,不同的调度法适用于不同的场景,需要根据具体情况选择合适的法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值