[2.2.1]进程管理——调度的概念、层次

news2025/7/17 14:20:17

文章目录

  • 第二章 进程管理
    • 调度的概念、层次
      • (一)调度的基本概念
      • (二)调度的三个层次
        • (1)高级调度
        • (2)低级调度
        • (3)中级调度
        • 补充知识:进程的挂起态与七状态模型
        • (4)三层调度的联系、对比
    • 小结

第二章 进程管理

调度的概念、层次

处理机调度

  • 基本概念
  • 三个层次
    • 高级调度(作业调度)
    • 中级调度(内存调度)
    • 低级调度(进程调度)
  • 三层调度的联系、对比
  • 补充知识
    • 进程的“挂起态”
    • 七状态模型

(一)调度的基本概念

  其实调度的概念离我们的生活并不遥远。

  比如在我们去银行的时候,这个银行,它可能有几个窗口为客户服务。那么,这些客户,到底应该先为谁服务呢?银行一般采用的是先到先服务的这种原则。

  如果说此时有一个vip客户,这个客户在银行里可能就会优先被服务、优先级更高。

image-20230308184703607

  再看另外一个例子。一个宿舍,早上大家都想上卫生间。每个人都想使用,但是有的人想使用3分钟,有的人要10分钟,有的人要1分钟……那么,大家在商量之后,就决定了一种使用这个资源的一个原则:使用时间短的就先使用,使用时间长的就后使用;如果时间长度相同的,先排队的先使用。

image-20230308184924476

  其实所谓的调度,它指的就是,当我们有一堆任务要处理的时候,由于当前的资源有限,那么这些事情没办法同时地被处理,那这个时候,我们就需要按照某种规则(比如先到先服务、时间短的优先),来决定我们要用什么样的顺序来处理这些任务。这就是所谓的“调度”。

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

(二)调度的三个层次

(1)高级调度

  我们来看一下,在一个程序整个生命周期内,什么时候会发生调度的情况。

  第一种,叫做高级调度,又叫作业调度。


  此处补充一下作业的概念。

  所谓的作业,指的就是某一个具体的任务。

  可能有时会看到这种描述:用户向操作系统提交了一个作业。

  这句话,其实可以理解为:用户让操作系统帮他启动某一个程序,这个程序是来处理某一个具体的任务的。


  我们知道,我们要启动一个程序,那么这个程序相关的数据肯定需要从外存放到内存里面。

  但是我们的内存资源又是有限的。

  所以,如果内存已经满了,那么我们给操作系统提交的作业(或者我们想让系统帮我们启动的这个程序)就有可能没办法马上把它们放入内存(没办法马上启动)。

image-20230308185706788

  在这个时候,操作系统就会做高级调度(作业调度)。

image-20230308185925640

  操作系统会按照作业调度的相关规则,从作业后备队列里面选择一个先把它调入内存,并且会为这个作业建立与它相对应的进程,也就是建立一个PCB。这就是高级调度(作业调度)要做的事情。如果当前用户提交了很多作业,操作系统就要决定接下来到底要执行哪一个作业。

  高级调度(作业调度):按一定的原则从外存的作业后备队列中挑选一个作业调入内存,并创建进程。简化理解:好几个程序需要启动,到底先启动哪个。

  每个作业只调入一次,调出一次。作业调入时会建立PCB,调出时才撤销PCB。

(2)低级调度

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

image-20230308190500198

  因为我们内存中同一时刻是存在很多进程的,而我们CPU的资源也是有限的。所以,操作系统也需要按某种策略,从我们的进程就绪队列中挑选出一个进程,把处理机资源分配给它。

  多道程序并发,这件事情,肯定要用到进程调度。

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

  并且,进程调度的频率是很高的,一般几十毫秒一次。因为高频率的进程调度,才可以让各个进程很快速地、轮流地上CPU执行。这样才可以让用户在宏观上看,好像是各个进程在同时运行。

(3)中级调度

  刚才我们说过,计算机当中有可能出现内存资源不足的情况。内存里面此时存在多个进程的数据。

image-20230308191010895

  而如果内存不足的话,其实我们是可以让一些不太紧急、不太重要的进程,先把这些进程的数据从内存调出到外存。

image-20230308191039857

  如果一个进程的数据,把它从内存放入到了外存里面,那这个进程此时就处于挂起状态。操作系统会把这些进程的PCB组织起来成为一个队列,叫挂起队列。(类似于之前说过的就绪队列、阻塞队列)

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

image-20230308191213786

  那此时已经有空闲的内存资源了,操作系统又可以通过某一种调度策略,来决定,到底要把哪个进程的数据先调回内存。这个就是中级调度管的事情,又叫内存调度。

image-20230308191348846

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

  我们平时用手机的时候会有这样的体验:有时在切换程序(切换进程)的时候,有的时候会发现切换的很快,而有的时候切换的又很慢。有种可能的原因就是,当切换很快的时候,这个进程的数据有可能是位于内存里面的;而切换进程很慢的时候,有可能是因为那个进程的数据已经不在手机内存里,而是被系统调到了外存当中,所以当你切换到这个进程的时候,系统会发现,这个进程此时非运行不可了,它再把相关的数据从外存再读回内存。

  那么显然,在进程运行的生命周期内,有可能会多次调出、调入内存,所以中级调度发生的频率肯定要比高级调度的频率更高

补充知识:进程的挂起态与七状态模型

  刚刚提到了挂起状态。此处再补充一个与挂起状态相关的,七状态模型。

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

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

  之前已经学习了进程的五状态模型。这是考研408里要求掌握的一种模型。

image-20230308192518216

  但对于一些自主命题的学校,也有可能要掌握七状态模型。总之了解一下。

  那么,在引入了就绪挂起、阻塞挂起两种状态之后,一个处于就绪态的进程,如果此时这个系统的负载比较高、内存空间已经不够用了,那么它有可能会把一个处于就绪态的进程,把它暂时调到外存当中,这个进程就进入了一个就绪挂起的状态。一直到内存空闲,或者这个进程急需进行,那么这个进程又会被激活,并把它相应数据挪回内存中。

  同样地,一个阻塞态的进程也可以被挂起,相应的也可以被激活、重新调入内存。

  而有的操作系统,对于处于阻塞挂起的进程,当它等待的阻塞事件发生的时候,这个进程会从阻塞挂起变为就绪挂起。之后,当它再被重新调回内存的时候,直接就是就绪态,而不是回到阻塞态。

image-20230308193039232

  还有的时候,一个进程处于运行态,当运行结束之后,可能这个进程下处理机的时候就会被直接放到外存当中,让它进入就绪挂起的状态。

  而有的时候,一个处于创建态的进程,当它创建结束之后、创建完PCB之后,有可能出现内存空间不够的情况,那这种情况下有可能,处于创建态的进程,创建之后处于就绪挂起的状态。

image-20230308193257053

  需要注意的是,“挂起”和“阻塞”的区别。

  这两种状态都是暂时不能获得CPU的服务,但区别在于,处于挂起态的进程,进程映像是放在外存里的;而处于阻塞态的进程,它的进程映像其实还在内存当中。

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

  以上就是七状态模型。

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

image-20230308193606060

小结

image-20230308193914382

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/396612.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第三篇:字符显示原理

使用PCtolLCD2003制作字库注意,我们开始取模前一定要记得设置取模方式,这个取模方式和我们显示屏的显示方式要一致设置字体为宋体,字体大小为16*16(这里当然可以设为别的)输入想要显示的字点击生成字模u8 shuai[] {0x10,0x04,0x10,0x04,0x12,0x04,0x12,0x04,0x92,0x3F,0x92,0x…

HTML 编辑器

文章目录 HTML 编辑器HTML 编辑器推荐编辑器下载网站HBuilder步骤 1: 新建 HTML 文件步骤 2: 另存为 HTML 文件步骤 3: 在浏览器中运行这个 HTML 文件HTML 编辑器 HTML 编辑器推荐 可以使用专业的 HTML 编辑器来编辑 HTML,我为大家推荐几款常用的编辑器: Notepad++:Windows…

蓝桥dfs专题

1、dfs 路径打印 小明冒充X星球的骑士,进入了一个奇怪的城堡。 城堡里边什么都没有,只有方形石头铺成的地面。 假设城堡地面是 n x n 个方格。【如图1.png】所示。 按习俗,骑士要从西北角走到东南角。 可以横向或纵向移动,但不能…

SpringBoot基础知识

1 SpringBoot简介1.1 入门官网创建SpringBoot项目&#xff1a;https://start.spring.io/快速启动SpringBoot工程&#xff1a;SpringBoot程序可以不依赖Tomcat和IDE&#xff0c;源码工程打完jar后可以直接运行。java -jar springboot_quick_start-0.0.1-SNAPSHOT.jar1.2 简介<…

OAK相机如何将yoloV5lite模型转换成blob格式?

编辑&#xff1a;OAK中国 首发&#xff1a;oakchina.cn 喜欢的话&#xff0c;请多多&#x1f44d;⭐️✍ 内容可能会不定期更新&#xff0c;官网内容都是最新的&#xff0c;请查看首发地址链接。 ▌前言 Hello&#xff0c;大家好&#xff0c;这里是OAK中国&#xff0c;我是助手…

Hadoop 使用Linux操作系统与Java熟悉常用的HDFS操作

注意看评论区获取完整代码资料 目录 一、实验目的 二、实验平台 三、实验步骤 一、实验目的 理解HDFS在Hadoop体系结构中的角色&#xff1b;熟练使用HDFS操作常用的Shell命令&#xff1b;熟悉HDFS操作常用的Java API。 二、实验平台 操作系统&#xff1a;Linux&#xff0…

运筹系列68:TSP问题Held-Karp下界的julia实现

1. 介绍 Held-Karp下界基于1tree下界&#xff0c;但是增加了点权重&#xff0c;如下图 通过梯度下降的方法找到最优的π\piπ。 这里用到的1tree有下面几种&#xff1a; 全部点用来生成最小生成树&#xff0c;再加上所有叶子结点第二短的边中数值最大的那个任意选一个点&…

Java集合进阶(一)

文章目录一、Collection1. 概述2. 常用方法3. 集合遍历4. 案例二、List1. 概述2. 特有方法3. 并发修改异常4. 列表迭代器5. 增强 for 循环6. 数据结构6.1 栈和队列6.2 数组和链表7. List 子类特点7.1 LinkedList一、Collection 集合类的特点&#xff1a;提供一种存储空间可变的…

raspberry Pi 连接蓝牙(小爱同学)

参数valueraspberry pi MOdel4B&#xff0c;4Gbbluetooth MOdel小爱同学writeTime2023年 2月11日 下午13&#xff1a;14分raspberry System ModelLinux raspberrypi 5.15.61-v8 #1579 SMP PREEMPT Fri Aug 26 11:16:44 BST 2022 aarch64 GNU/Linux 连接蓝牙 请在小爱同学app上…

Linux 网络编程(UDP模型,libevent库使用)

1.ctags的使用安装命令&#xff1a;sudo apt install exuberant-ctags要使用ctags需要在当前目录生成 tags 文件&#xff0c;可以组织目录内所有.c间函数调用关系生成方法&#xff1a;1.在项目目录下输入命令&#xff1a;ctags ./* -R2.在任意一个文件内使用 ctrlp一些快捷命令…

python入门项目06:批量处理文件

文章目录前言一、理论知识1.1 OS模块1.2 XML的解析二、使用步骤1.引入库2.创建新文件夹3文件操作4 修改文件总结前言 本文要完成的是对于较多XML文档的自动修改&#xff0c;这部分往往在大量的图像标注的修改中会使用到&#xff0c;同时也不要局限于本文中所提到的使用场景。 …

springbboot随笔

无效的源发行版问题 改springboot版本 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http:…

高校竞赛信息管理系统

摘要随着当今社会的发展&#xff0c;时代的进步&#xff0c;各行各业也在发生着变化&#xff0c;比如高校竞赛信息管理这一方面&#xff0c;利用网络已经逐步进入人们的生活。传统的高校竞赛信息管理&#xff0c;都是学生去学校查看竞赛信息然后再进行报名&#xff0c;这种传统…

linux面试高级篇

题目目录1.虚拟机常用有几种网络模式&#xff1f;请简述其工作原理或你个人的理解&#xff1f;2. Dockerfile中最常见的指令是什么&#xff1f;3.docker网络模式有哪些&#xff1f;4.Kubernetes有哪些核心组件这些组件负责什么工作&#xff1f;5. Pod是什么&#xff1f;6.描述一…

H264编码原理

1.什么是音视频&#xff1f; 比如我们下载的mp4格式&#xff08;还有rmvb、avi&#xff09;的电影 2.什么是h264&#xff1f; 对摄像头采集的每一帧视频需要进行编码&#xff0c;由于视频中存在空间和时间的冗余&#xff0c; 需要用算法来去除这些冗余。H264是专门去除这些冗…

SQL基础语句小结

&#x1f34e;道阻且长&#xff0c;行则将至。&#x1f353; 目录 一、SQL概述 1.简介 2.格式语法 3.SQL分类 二、DDL操作数据库 1.创建数据库 2.查询与使用 3.删除数据库 三、DDL:操作表 (1)数据类型 (2)创建表 (3)查询当前数据库的表 (4)删除表 (5)修改表 四、DML…

小鹏汽车「错失」智能化好牌

本周&#xff0c;作为小鹏品牌销售主力的P7正式迎来改款发布。3月6日&#xff0c;小鹏P7i迎来首发&#xff0c;作为P7的改款车型&#xff0c;在整车电子架构、三电系统、智能化硬件配置上都进行了全面升级。 基于和G9相同的双Orin-X计算平台两个盲区激光雷达&#xff0c;P7i实现…

RocketMQ基础篇(一)

目录一、发送消息类型1、同步消息2、异步消息3、单向消息4、顺序消费5、延迟消费二、消费模式1、集群模式2、广播模式3、消费模式扩展4、如何配置三、其他用法1、事务消息2、过滤消息1&#xff09;Tag过滤2&#xff09;SQL方式过滤源码放到了GitHub仓库上&#xff0c;地址 http…

HyperLPR3车牌识别-Android-SDK光速部署与使用

简介HyperLPR在2023年初已经更新到了v3的版本&#xff0c;该版本与先前的版本一样都是用于识别中文车牌的开源图像算法项目&#xff0c;最新的版本的源码可从github中提取&#xff1a;https://github.com/szad670401/HyperLPRHyperLPR-Android-SDK for JitPackHyperLPR3的官方源…

Prim算法和Kruskal算法到底哪个好?

Prim和Kruskal有啥区别&#xff1f;到底哪个好&#xff1f; 今天做了一道最小生成树的题&#xff0c;发现了一点猫腻&#xff01; 题目在这里 &#xff1a; 《修路问题1》 文章目录Prim和Kruskal有啥区别&#xff1f;到底哪个好&#xff1f;先说结论PrimKruskal修路问题1——…