2.2_1 调度的概念、层次

2.2_1 调度的概念、层次

image-20240229140724446

(一)调度的基本概念

  当有一堆任务要处理,但由于资源有限,这些事情没法同时处理。这就需要确定某种规则决定处理这些任务的顺序,这就是“调度”研究的问题。

image-20240229141017981

(二)调度的三个层次——高级调度(作业调度)

  作业:一个具体的任务。

  用户向操作系统提交一个作业,可以理解为:用户让操作系统启动一个程序(来处理一个具体的任务)。

image-20240229141156066

  高级调度(作业调度):按一定的原则从外存的作业后背队列中挑选一个作业调入内存,并创建进程。每个作业只调入一次,调出一次。作业调入时会建立PCB,调出时才撤销PCB。

  简化理解:好几个程序需要启动,到底先启动哪个。

(三)调度的三个层次——低级调度(进程调度/处理机调度)

image-20240229142110042

  低级调度(进程调度/处理机调度)——按照某种策略从就绪队列中选取一个进程,将处理机分配给它。

  进程调度是操作系统中最基本的一种调度,在一般的操作系统中都必须配置进程调度。

  进程调度的频率很高,一般几十毫秒一次。

  只有高频率的进程调度,才能让各个进程都能很快速的上CPU运行,这样才能让用户在宏观上看,好像各个进程是同时执行的一样。

(四)调度的三个层次——中级调度(内存调度)

image-20240229142507705

  内存不够时,可将某些进程的数据调出外存。等内存空闲或者进程需要运行时再重新调入内存。

  暂时调到外存等待的进程状态为挂起状态。被挂起的进程PCB会被组织成挂起队列

  中级调度(内存调度):按照某种策略决定将哪个处于挂起状态的进程重新调入内存。

  一个进程可能会被多次调出、调入内存,因此中级调度发生的频率要比高级调度更高

(五)进程的挂起态与七状态模型

image-20240229143143475

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

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

注意

  “挂起”和“阻塞”的区别。

  两种状态都是暂时不能获得CPU的服务,但挂起态是将进程映像调到外存去了,而阻塞态下进程映像还在内存中。

  有的操作系统会把就绪挂起、阻塞挂起分为两个挂起队列,甚至会根据阻塞原因不同再把阻塞挂起进程进一步细分为多个队列。

(六)三层调度的联系、对比

image-20240229143605299

总结

image-20240229143754741

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋秋秋叶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值