• 处理机调度的概念,层次联系以及七状态模型


    1.基本概念

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

    2. 三个层次

    1.高级调度(作业调度

    高级调度(作业调度):按一定的原则从外存的作业后备队列中挑选一个作业调入内存,并创建进程

    1. 作业:一个具体的任务
    2. 用户向系统提交一个作业 =用户让操作系统启动一个程序(来处理一个具体的任务)
    3. 每个作业只调入一次,调出一次。
    4. 作业调入时会建立PCB,调出时才撤销PCB。
    2.中级调度(内存调度)

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

    1. 内存不够时,可将某些进程的数据调出外存。
    2. 等内存空闲或者进程需要运行时再重新调入内存。
    3. 暂时调到外存等待的进程状态为挂起状态
    4. 被挂起的进程PCB会被组织成挂起队列
    5. 一个进程可能会被多次调出、调入内存,因此中级调度发生的频率要比高级调度更高。
    3.低级调度(进程调度

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

    1. 进程调度是操作系统中最基本的一种调度,在一般的操作系统中都必须配置进程调度。
    2. 进程调度的频率很高,一般几十毫秒一次。

    3.三层调度的联系,对比

    在这里插入图片描述

    4.进程的挂起态

    暂时调到外存等待的进程状态为挂起状态(挂起态,suspend)
    挂起态又可以进一步细分为就绪挂起、阻塞挂起两种状态

    5.七状态模型

    五状态模型到七状态模型
    在这里插入图片描述

    1. 注意“挂起”和“阻塞”的区别,两种状态都是暂时不能获得CPU的服务,但挂起态是将进程映像调到外存去了,而阻塞态下进程映像还在内存中。
    2. 有的操作系统会把就绪挂起、阻塞挂起分为两个挂起队列,甚至会根据阻塞原因不同再把阻塞挂起进程进一步细分为多个队列。
  • 相关阅读:
    数据结构与算法--排序算法复习
    NRF24L01数据通信C程序
    SpringBoot--配置Redisson的方法
    idea 创建打包 android App
    高等数学(第七版)同济大学 习题4-2(前半部分) 个人解答
    JS Echarts之雷达图 | 使用Excel画雷达图
    axios
    数据结构与算法--分治策略
    井盖异动传感器丨井盖状态监测仪助力排水管网系统装上“眼睛”
    实用小算法
  • 原文地址:https://blog.csdn.net/qq_61888137/article/details/133531412