操作系统(7)处理机调度

前言

       操作系统中的处理机调度是一个核心概念,它涉及如何从就绪队列中选择进程并将处理机分配给它以运行,从而实现进程的并发执行。

一、调度的层次

  1. 高级调度(作业调度)

    • 调度对象:作业(包含程序、数据以及作业说明书)。
    • 功能:从外存上处于后备队列的作业中挑选一个或多个作业,给它们分配内存等必要资源,并建立相应的进程(建立PCB),以使它们获得竞争处理机的权利。
    • 特点:高级调度是辅存(外存)与内存之间的调度。每个作业只调入一次,调出一次。作业调入时会建立相应的PCB,作业调出时才撤销PCB。高级调度主要是指调入的问题,因为只有调入的时机需要操作系统来确定,但调出的时机必然是作业运行结束才调出。
  2. 中级调度(内存调度)

    • 目的:提高内存利用率和系统吞吐量。
    • 功能:决定将哪个处于挂起状态的进程重新调入内存。挂起态是指暂时被调到外存中等待的进程状态。
    • 特点:中级调度发生的频率比高级调度高,因为进程可能会被多次调出、调入内存。此外,中级调度引入了虚拟存储技术,可将暂时不能运行的进程调至外存等待,等它重新具备了运行条件且内存又稍有空闲时,再重新调入内存。
  3. 低级调度(进程调度)

    • 调度对象:进程。
    • 功能:从就绪队列中按照某种方法和策略选取一个进程,将处理机分配给它。低级调度是操作系统中最基本的一种调度,在一般的操作系统中都必须配置进程调度。
    • 机制:低级调度包含三个基本机制,即排队器(系统中的所有就绪进程都应按照一定的方式进行排序)、分派器(取出选中进程,进行上下文切换,后分配处理机资源)和上下文切换(对处理机进行切换时,需要进行两对上下文切换)。

二、调度的时机与方式

  1. 调度时机

    • 进程状态发生变化时(如从就绪态到运行态、从运行态到阻塞态或从运行态到结束态)会触发调度。
    • 硬件时钟提供周期性中断时,也可以触发调度。
  2. 调度方式

    • 非抢占式调度:挑选一个进程,然后让该进程运行直到被阻塞或退出,才会调用另外一个进程。这种调度方式下,进程不会因为时钟中断而被抢占。
    • 抢占式调度:挑选一个进程,然后让该进程只运行某段时间(称为时间片)。如果在该时段结束时,该进程仍然在运行时,则会把它挂起,接着调度程序从就绪队列挑选另外一个进程。这种调度方式需要时钟中断来将CPU控制返回给调度程序进行调度。

三、调度算法及其评价指标

  1. 调度算法

    • 先来先服务(FCFS):按照进程进入就绪队列的先后顺序进行调度。这种算法对长作业有利,但可能导致短作业长时间等待。
    • 最短作业优先(SJF):选择估计运行时间最短的进程进行调度。这种算法有助于提高系统吞吐量,但对长作业不利。SJF可以分为抢占式和非抢占式两种。
    • 高响应比优先(HRRN):权衡了短作业和长作业。每次进行进程调度时,先计算响应比优先级,然后把响应比优先级最高的进程投入运行。响应比优先级的计算公式为:响应比=(等待时间+要求服务时间)/要求服务时间。
    • 时间片轮转(Round Robin, RR):每个进程被分配一个时间段(称为时间片),允许该进程在该时间段中运行。如果时间片用完,进程还在运行,则将其从CPU释放出来,并把CPU分配给另外一个进程。时间片轮转算法是最古老、最简单、最公平且使用最广的算法之一。
    • 优先级调度:根据进程的优先级进行调度。优先级可以是静态的(在创建进程时确定,并在执行过程中不会改变),也可以是动态的(根据进程的动态变化调整优先级)。
  2. 评价指标

    • CPU利用率:CPU忙碌时间占总时间的比例。
    • 系统吞吐量:单位时间内完成的作业数量。
    • 周转时间:从作业被提交给系统开始到作业完成为止的这段时间间隔。
    • 等待时间:进程或作业处于等待处理机状态的时间之和。
    • 响应时间:用户提交请求到首次产生响应所需要的时间。

四、实时调度与死锁

  1. 实时调度

           实时系统中需要及时反馈,因此前面的算法可能不能满足实时系统对调度的要求。实时调度算法需要满足实时任务的时间约束,常见的实时调度算法有最早截止时间优先(EDF)和最低松弛度优先(LLF)等。
  2. 死锁

           死锁是指两个或多个进程因争夺资源而无限期地阻塞、相互等待的一种状态。产生死锁的原因包括竞争资源、进程间推进顺序非法等。预防死锁的方法包括摒弃“请求和保持条件”、摒弃“不可剥夺条件”和摒弃“环路等待条件”等。

总结

       综上所述,操作系统中的处理机调度是一个复杂而关键的过程,它涉及多个层次、多种时机与方式以及多种算法和评价指标。在实际应用中,需要根据系统的具体需求和特点选择合适的调度策略和算法。

 结语      

生活在阴沟里

仍然有仰望星空的权利

!!!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Acer宏碁Swift3笔记本S40-20,SF314-56G原厂Win10系统工厂模式安装包,带Recovery恢复还原

适用电脑型号:S40-20、SF314-56、SF314-56G(原装OEM预装系统) 链接:https://pan.baidu.com/s/1q77Br-hcmn9iJraGVVKQ7Q?pwdrw1r 提取码:rw1r Acer宏碁原装出厂windows10系统自带所有驱动、Office办公软件、出厂主题壁纸、系统属性专属联…

XML 在线格式化 - 加菲工具

XML 在线格式化 打开网站 加菲工具 选择“XML 在线格式化” 输入XML,点击左上角的“格式化”按钮 得到格式化后的结果

JIS-CTF: VulnUpload靶场渗透

JIS-CTF: VulnUpload来自 <https://www.vulnhub.com/entry/jis-ctf-vulnupload,228/> 1,将两台虚拟机网络连接都改为NAT模式 2&#xff0c;攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 靶机IP地址192.168.23.162&#xff0c;攻击机IP地址192.168.23.140…

Linux(网络协议和管理)

后面也会持续更新&#xff0c;学到新东西会在其中补充。 建议按顺序食用&#xff0c;欢迎批评或者交流&#xff01; 缺什么东西欢迎评论&#xff01;我都会及时修改的&#xff01; 在这里真的很感谢这位老师的教学视频让迷茫的我找到了很好的学习视频 王晓春老师的个人空间…

【Flask+OpenAI】利用Flask+OpenAI Key实现GPT4-智能AI对话接口demo - 从0到1手把手全教程(附源码)

文章目录 前言环境准备安装必要的库 生成OpenAI API代码实现详解导入必要的模块创建Flask应用实例配置OpenAI API完整代码如下&#xff08;demo源码&#xff09;代码解析 利用Postman调用接口 了解更多AI内容结尾 前言 Flask作为一个轻量级的Python Web框架&#xff0c;凭借其…

挚达科技亏损暴增无底洞:毛利率下滑,产品销量增长但单价下降

《港湾商业观察》廖紫雯 日前&#xff0c;上海挚达科技发展股份有限公司&#xff08;以下简称&#xff1a;挚达科技&#xff09;再次递表港交所&#xff0c;最新财务数据显示&#xff0c;2024年前九个月&#xff0c;公司营收较上年同期出现下滑&#xff0c;且往绩期间&#xf…

每天五分钟深度学习pytorch:基于LeNet算法模型完成手写字体识别

本文重点 LeNet是我们要介绍的第一个经典的卷积神经网络模型,它是一种用于手写体字符识别的非常高效的卷积神经网络。它是卷积神经网络的祖师爷LeCun在1998年提出,它将CNN的最基本的架构就定下来了:卷积层、池化层、全连接层。 它的算法模型的效果图为: 本文我们讲解基于…

全栈开发:后台管理系统时代的技术破局之道

在当前的互联网发展阶段&#xff0c;许多二三线城市的互联网项目正在经历一个显著的转变。传统的To C项目逐渐减少&#xff0c;取而代之的是大量的企业级后台管理系统。在这样的背景下&#xff0c;全栈开发——特别是前端加Java的组合&#xff0c;正在成为一个备受关注的发展方…

AI Agent:重塑业务流程自动化的未来力量(2/30)

《AI Agent&#xff1a;重塑业务流程自动化的未来力量》 摘要&#xff1a;整体思路是先介绍 AI Agent 的基本情况&#xff0c;再深入阐述其实现业务流程自动化的方法和在不同领域的应用&#xff0c;接着分析其价值和面临的挑战&#xff0c;最后得出结论&#xff0c;为读者全面…

网页端web内容批注插件:

感觉平时每天基本上90%左右的时间都在浏览器端度过&#xff0c;按理说很多资料都应该在web端输入并且输出&#xff0c;但是却有很多时间浪费到了各种桌面app中&#xff0c;比如说什么notion、语雀以及各种笔记软件中&#xff0c;以及导入到ipad的gn中&#xff0c;这些其实都是浪…

vue2实现多段打字机效果

实现效果 多段打字&#xff0c;每段之间延迟一点时间&#xff0c;末尾有光标 页面结构 所有的“打字”的效果都在typedText里面展现&#xff0c;打印完了就把这一段加入displayedParagraphs中&#xff0c;同时清空typedText。 displayedParagraphs就是正常v-for渲染 数据结…

力扣打卡14:多数元素

链接&#xff1a;169. 多数元素 - 力扣&#xff08;LeetCode&#xff09; 这道题正常很简单&#xff0c;但是如果想要完成进阶做法有点困难。我使用了O(n/2)左右的空间&#xff0c;使用了哈希映映射。 看了题解&#xff0c;有一种解法叫摩尔投票&#xff0c;可以解决这种问题…

SQL server学习03-创建和管理数据表

目录 一&#xff0c;SQL server的数据类型 1&#xff0c;基本数据类型 2&#xff0c;自定义数据类型 二&#xff0c;使用T-SQL创建表 1&#xff0c;数据完整性的分类 2&#xff0c;约束的类型 3&#xff0c;创建表时创建约束 4&#xff0c;任务 5&#xff0c;由任务编写…

【网络攻击与防范】常见服务的配置方法

一、DHCP 服务的安装与配置 1、安装 2、验证安装 3、启动、停止和重新启动 4、配置作用域 Scope 检验配置&#xff1a;netsh 5、DHCP服务器选项 6、利用 kali 客户端来进行验证 将 kali 的网卡也设置在 VMnet2 中&#xff1a; 二、DNS服务的安装与配置 1、安装 2、验证安装 …

移动端h5自适应rem适配最佳方案

网页开发中&#xff0c;我们常用的单位有如下几个&#xff1a; px&#xff1a;像素固定&#xff0c;无法适配各分辨率的移动设备em: 该单位受父容器影响&#xff0c;大小为父元素的倍数rem: 因为html根元素大小为16px&#xff0c;所以默认 1rem 16px&#xff0c;rem只受根元素…

ubuntu20.04复现 Leg-KILO

这里写目录标题 opencv版本问题下载3.2.0源代码进入解压后的目录创建构建目录运行 CMake 配置 配置时指定一个独立的安装目录&#xff0c;例如 /opt/opencv-3.2&#xff1a;出错&#xff1a; 使用多线程编译错误1&#xff1a; stdlib.h: 没有那个文件或目录错误2&#xff1a;er…

Python爬虫之Selenium的应用

【1】Selenium基础介绍 1.什么是selenium&#xff1f; &#xff08;1&#xff09;Selenium是一个用于Web应用程序测试的工具。 &#xff08;2&#xff09;Selenium 测试直接运行在浏览器中&#xff0c;就像真正的用户在操作一样。 &#xff08;3&#xff09;支持通过各种driv…

回归预测 | MATLAB实现BiGRU(双向门控循环单元)多输入单输出

回归预测 | MATLAB实现BiGRU(双向门控循环单元)多输入单输出 文章目录 回归预测 | MATLAB实现BiGRU(双向门控循环单元)多输入单输出预测效果基本介绍程序设计参考资料致谢预测效果 基本介绍 BiGRU(双向门控循环单元)多输入单输出模型是一种结合了双向门控循环单元(BiGRU)的…

React的状态管理库-Redux

核心思想&#xff1a;单一数据源、状态是只读的、以及使用纯函数更新状态。 组成部分 Store&#xff08;存储&#xff09; 应用的唯一状态容器&#xff0c;存储整个应用的状态树,使用 createStore() 创建。 getState()&#xff1a;获取当前状态。dispatch(action)&#xff…

.NET平台使用C#设置Excel单元格数值格式

设置Excel单元格的数字格式是创建、修改和格式化Excel文档的关键步骤之一&#xff0c;它不仅确保了数据的正确表示&#xff0c;还能够增强数据的可读性和专业性。正确的数字格式可以帮助用户更直观地理解数值的意义&#xff0c;减少误解&#xff0c;并且对于自动化报告生成、财…