处理机调度
目录
处理机调度概述
处理机调度的层次
低级调度
中级调度
高级调度
进程调度
进程调度的时机
进程调度的方式
非抢占式调度方式
抢占式调度方式
调度算法的评价指标
调度算法
先来先服务调度算法(FCFS,First Come First Serve)
短作业优先调度算法(SJF)
非抢占式短作业优先调度算法
抢占式短作业优先调度算法
优先级调度算法
优先级的类型
非抢占式的优先级调度算法
抢占式优先级调度算法
高响应比优先调度算法(HRRN)
处理机调度总结

处理机调度概述
在多道程序的环境中,内存中存在多个进程,进程的数目多于处理机数目。此时在为进程分配处理机时需要进行处理机的调度。处理机的调度就是分配处理机。处理机调度算法就是按照处理机分配策略按照规定分配处理机的算法。
处理机调度的层次
低级调度、中级调度、高级调度。运行频率:低级 > 中级 > 高级。
低级调度
低级调度又称为短程调度或进程调度,调度的对象是进程。按照某种算法,决定就绪队列中哪个进程优先分配处理机。
中级调度
中级调度又称为内存调度。作用是:提高内存的利用率和系统的吞吐量。中级调度是将内存中暂时不能运行的进程调入外存,进程的状态变为挂起状态。当进程能够运行且处理机有空闲时,调入内存中,并修改进程的状态为就绪状态。
高级调度
高级调度又称为长程调度,调度的对象是作业。高级调度是按照某种算法,决定处于后备队列中的作业哪几个作业调入内存,并为他们创建进程,分配资源,为这些进程放入就绪队列。
高级调度周期长,运行效率低。
进程调度
进程调度的时机
进程在停止或放弃继续执行分为两种:
第一种:主动放弃
进程结束;进程执行过程中因异常中断;进程在I/0主动请求时,发生阻塞;
第二种:被动放弃
进程的时间片完;有更紧急的事件需要处理;有更高优先级的进程进入就绪队列。
进程调度的方式
非抢占式调度方式
只允许进程主动放弃处理机。只要进程在执行,即使有更紧急的事件需要处理,处理机依然执行,直到进程主动放弃处理机。
优点:实现简单,系统开销小。但无法处理及时紧急的任务。
抢占式调度方式
在一个进程执行的过程中,如果遇到紧急的事件需要处理,该进程或立即停止执行,处理机优先分配给紧急的任务。
抢占不是任意的行为,需要遵循优先级原则、短进程优先原则、时间片原则。
调度算法的评价指标
CPU利用率:cpu有效工作时间 / (CPU总时间)
系统吞吐量:单位时间内完成的作业数。 作业数 / 时间
周转时间: 作业完成时间 - 作业提交时间;
平均周转时间:周转时间 / 作业数 ;
带权周转时间: 作业周转时间 / 作业实际运行时间。
等待时间:等待被服务的时间。
调度算法
先来先服务调度算法(FCFS,First Come First Serve)
算法思想:按照作业/ 进程到达的时间进行调度。 FCFS算法为非抢占式的调度方式,即可用哦关于作业调度,也可进程调度。
优点:公平、实现简单。缺点:对于长作业后的短作业来说,需要等待很长时间,长作业的带权周转时间很大。
是否会产生饥饿现象?
饥饿(进程/ 作业长期得不到服务),FCFS算法不会导致饥饿。

短作业优先调度算法(SJF)
算法思想:最短的作业 / 进程优先得到服务。(运行时间最短的优先),短作业优先调度算法可以是抢占式的方式也可非抢占式的方式。
优点:平均等待时间和平均周转时间较短。缺点:对短作业有利,对长作业不利。
是否会产生饥饿现象?
会导致饥饿现象,如果短作业/ 短进程不断的进入就绪队列,长作业/ 进程就无法执行,产生饥饿现象。
非抢占式短作业优先调度算法

抢占式短作业优先调度算法


优先级调度算法
优先级调度算法是把处理机优先分配给优先级高的作业/ 进程。
优先级的类型
静态优先级:创建进程时确定静态优先级,在运行期间保持不变。确定的依据:进程的类型、进程所需要的资源大小、用户需求的紧急程度。
动态优先级:创建进程时确定优先级,在运行的期间是根据进程的要求服务时间和等待时间不断调整优先级的大小。
优先级调度算法,如果在进程运行的过程中不断的有优先级较高的进程加入就绪队列,优先级低的会持续等待执行,会产生饥饿现象。
非抢占式的优先级调度算法
(优先数越大,优先级越高)

抢占式优先级调度算法

高响应比优先调度算法(HRRN)
综合考虑作业/进程的要求服务时间和等待时间,解决先来先服务调度算法和短作业优先调度算法缺陷。非抢占式调度算法。
优先级=(等待时间+要求服务的时间)/要求服务时间,优先级也相当于响应比。
该算法的优点:
1、如果作业的等待时间相同,要求服务时间越短,优先级越高。
2、如果作业的要求服务时间相同,等待时间越长,优先级越高。
3、对于长作业,随着短进程/作业的加入,等待时间会变长,优先级不断调整。

相关文章:
处理机调度
目录 处理机调度概述 处理机调度的层次 低级调度 中级调度 高级调度 进程调度 进程调度的时机 进程调度的方式 非抢占式调度方式 抢占式调度方式 调度算法的评价指标 调度算法 先来先服务调度算法(FCFS,First Come First Serve) …...
Webpack 解决:ReferenceError: dist is not defined 的问题
1、问题描述: 其一、报错为: ReferenceError: dist is not defined 中文为: ReferenceError:dist 未定义 其二、问题描述为: 想在 webpack 的配置中,创建一个 dist 文件夹来存放 npm run build 打包后…...
MySQL的index merge(索引合并)导致数据库死锁分析与解决方案 | 京东云技术团队
背景 在DBS-集群列表-更多-连接查询-死锁中,看到9月22日有数据库死锁日志,后排查发现是因为mysql的优化-index merge(索引合并)导致数据库死锁。 定义 index merge(索引合并):该数据库查询优化的一种技术࿰…...
第四章 网络层 | 计算机网络(谢希仁 第八版)
文章目录 第四章 网络层4.1 网络层提供的两种服务4.2 网际协议IP4.2.1 虚拟互连网络4.2.2 分类的IP地址4.2.3 IP地址与硬件地址4.2.4 地址解析协议ARP4.2.5 IP数据报的格式4.2.6 IP层转发分组的流程 4.3 划分子网和构造超网4.3.1 划分子网4.3.2 使用子网时分组的转发4.3.3 无分…...
课题学习(八)----卡尔曼滤波动态求解倾角、方位角
一、 卡尔曼滤波 卡尔曼滤波的应用要求系统和底层过程的测量模型都是线性的。离散时间线性状态空间系统的描述为: x k Φ k , k − 1 x k − 1 G k − 1 w k − 1 x_k\Phi_{k,k-1}x_{k-1}G_{k-1}w_{k-1} xkΦk,k−1xk−1Gk−1wk−1 式中 Φ k , k − 1 \Phi_{…...
仿真软件Proteus8.9 SP2 Pro 下载、安装、汉化详细图文教程
Proteus8.9 安装教程 视频教程一、安装软件解压二、软件安装常见问题及解决方法:三、汉化 Proteus8.9 SP2 Pro 安装教程 本破解教程仅供个人及 proteus 8.9粉丝们交流学习之用,请勿用于商业用途, 谢谢支持。此版本为Proteus8.9 SP2 Pro。其他…...
振弦传感器和无线振弦采集仪在隧道安全监测的解决方案
振弦传感器和无线振弦采集仪在隧道安全监测的解决方案 隧道作为交通工程的重要组成部分,具有极高的安全风险,因此隧道安全监测是必不可少的。振弦传感器和无线振弦采集仪作为隧道安全监测的两种重要设备,能够有效地监测隧道的振动情况&#…...
c# xml 参数读取的复杂使用
完整使用2 生产厂家里面包含很多规格型号,一个规格型号里面包含很多出厂序列号,点击下一步如果检测到填充的和保存的不一样 就新增一条(如检测到生产厂家相同,但是规格型号不同,就新增一组规格型号)。 界面一:新增界面 界面2 删除界面 界面一:新增界面 load 其中…...
在Mac中使用 brew services start redis 命令启动、停止Redis服务报错
一、问题现象 启动Redis服务命令: brew services start redis异常信息如下: Error: uninitialized constant Homebrew::Service::System /opt/homebrew/Library/Homebrew/macos_version.rb:150:in const_missing /opt/homebrew/Library/Taps/homebrew…...
iapp源码-----比较经典
2.0底部菜单导航栏.rar: https://url18.ctfile.com/f/7715018-958700751-6096bd?p6511 (访问密码: 6511) 2.0涟漪_拖动条控制音乐播放.rar: https://url18.ctfile.com/f/7715018-958700754-4cec13?p6511 (访问密码: 6511) 2.0手电筒.rar: https://url18.ctfile.com/f/7715018…...
为什么手机会莫名多出许多软件?
许多手机用户都曾遭遇过这样的问题,他们在使用手机的过程中,突然发现手机屏幕上出现了一些未知的软件。这些软件并非他们主动下载的,但它们却显现在屏幕上。这些软件从何而来? 其实,这些软件往往是在浏览网页、阅读小…...
测试自动化的边缘:DevTestOps 和 DevSecOps
什么是 DevOps? DevOps 允许企业通过自动化基础设施、工作流程和持续测量应用程序的性能来提高开发人员和运营团队之间的协作和生产力。通过 DevOps,开发人员可以以小块的形式编写代码,以便在几个小时内集成、测试、监控和部署代码ÿ…...
fatal:Could not read from remote repository解决方法
Linux服务器如何连接GitHub? 生成SSH密钥 ssh-keygen -C “邮箱” -t rsa 存放位置一般是/root/.ssh/id_rsa 登录个人github,添加客户端生成的公钥 打开Settings,点击SSH and GPG keys,点击New SSH Key。Key中粘贴id_rsa.pub…...
数学基础
线性代数 关键词:线性方程组、矩阵、增广矩阵(系数矩阵、常数项矩阵)、阶梯型矩阵、行最简矩阵、最简形矩阵、向量系统、向量加法、向量空间、基本单位向量、线性相关、线性无关、Span张成空间、 向量乘法(点积、内积、外积、叉积…...
【Python】Python语言基础(上)
第一章 前言 1. Python简介 Python语言并不是新的语言,它早于HTTP 1.0协议5年,早于Java语言 4年。 Python是由荷兰人Guido van Rossum(吉多范罗苏姆)于1989年圣诞节期间在阿姆斯特丹休假时为了打发无聊的假期而编写的一个脚本…...
C#设计模式六大原则之依赖倒置原则
C#设计模式六大原则是单一职责原则、里氏替换原则、依赖倒置原则、接口隔离原则、迪米特法则、开闭原则。它们不是要我们刻板的遵守,而是根据实际需要灵活运用。只要对它们的遵守程度在一个合理的范围内,努为做到一个良好的设计。以下介绍C#依赖倒置原则…...
IDEA的使用(二)快捷键 (IntelliJ IDEA 2022.1.3版本)
1. IDEA中的常用快捷键 1.1 通用型快捷键 1.2 提高编写速度 ctrl shift ↑或↓ 只能在方法里面移动代码。 alt shift ↑或↓ 可以向方法外移动代码。 设置过自动导包,所以不用批量导包啦。 1.3 类结构、查找和查看源码 1.4 查找、替换和关闭 1.5 调整格式 1.6 De…...
微信小程序个人账号申请和配置详细教程
一、注册小程序管理账号 1、注册方法 在微信公众平台官网首页(mp.weixin.qq.com),点击右上角的“立即注册”按钮。 2、选择注册的账号类型 选择“小程序”,点击“查看类型区别”可查看不同类型账号的区别和优势。 3、填写邮箱和…...
opencv定位图片中的图案?
import cv2 as cv2def find_positions(image_path, small_image_path):# 读取大图和小图large_image cv2.imread(image_path)small_image cv2.imread(small_image_path)# 小图规格small_image_h, small_image_w small_image.shape[:2]# 对比大图与小图# 匹配模板res cv2.ma…...
高防CDN:网络安全的不可或缺之选
在当今数字化时代,网络攻击已经成为互联网上的一种不可避免的风险。为了应对不断升级的网络威胁,许多企业和组织正在采用高防御CDN(Content Delivery Network)技术,以确保他们的在线资产得到保护,用户体验得…...
eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)
说明: 想象一下,你正在用eNSP搭建一个虚拟的网络世界,里面有虚拟的路由器、交换机、电脑(PC)等等。这些设备都在你的电脑里面“运行”,它们之间可以互相通信,就像一个封闭的小王国。 但是&#…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
高等数学(下)题型笔记(八)空间解析几何与向量代数
目录 0 前言 1 向量的点乘 1.1 基本公式 1.2 例题 2 向量的叉乘 2.1 基础知识 2.2 例题 3 空间平面方程 3.1 基础知识 3.2 例题 4 空间直线方程 4.1 基础知识 4.2 例题 5 旋转曲面及其方程 5.1 基础知识 5.2 例题 6 空间曲面的法线与切平面 6.1 基础知识 6.2…...
如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...
NXP S32K146 T-Box 携手 SD NAND(贴片式TF卡):驱动汽车智能革新的黄金组合
在汽车智能化的汹涌浪潮中,车辆不再仅仅是传统的交通工具,而是逐步演变为高度智能的移动终端。这一转变的核心支撑,来自于车内关键技术的深度融合与协同创新。车载远程信息处理盒(T-Box)方案:NXP S32K146 与…...
Mysql8 忘记密码重置,以及问题解决
1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...
计算机基础知识解析:从应用到架构的全面拆解
目录 前言 1、 计算机的应用领域:无处不在的数字助手 2、 计算机的进化史:从算盘到量子计算 3、计算机的分类:不止 “台式机和笔记本” 4、计算机的组件:硬件与软件的协同 4.1 硬件:五大核心部件 4.2 软件&#…...
Proxmox Mail Gateway安装指南:从零开始配置高效邮件过滤系统
💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「storms…...
HTML前端开发:JavaScript 获取元素方法详解
作为前端开发者,高效获取 DOM 元素是必备技能。以下是 JS 中核心的获取元素方法,分为两大系列: 一、getElementBy... 系列 传统方法,直接通过 DOM 接口访问,返回动态集合(元素变化会实时更新)。…...
