操作系统-调度算法-1(先来先服务算法 短作业优先 高响应比优先 )

2024-01-31 18:44

本文主要是介绍操作系统-调度算法-1(先来先服务算法 短作业优先 高响应比优先 ),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 总览
  • 先来先服务算法
    • 例题
  • 短作业优先
    • 例题(非抢占式的短作业优先调度算法)
    • 例题(抢占式的短作业优先调度算法)
    • 注意
  • FCFS和SJF两种算法的思考
  • 高响应比优先
    • 例题
  • 小结

总览

在这里插入图片描述

先来先服务算法

不会导致饥饿:只要该进程或作业在队列中,那么当其前面的都执行完(前面的总会执行完)后终将会轮到它被服务
在这里插入图片描述

例题

注意运行时间是在CPU运行的时间
等待时间=周转时间-被服务的时间
IO操作和CPU运行都是被服务的时间
在这里插入图片描述

短作业优先

”最短的“:不严谨,看情况判断对错
源源不断地短作业到来的话,长作业可能会产生饥饿现象
在这里插入图片描述

例题(非抢占式的短作业优先调度算法)

时刻零的时候只能执行P1进程,当执行完P1进程后,发现P2和P3和P4都到达了,此时执行运行时间最短的P3,然后P2和P4的运行时间都是一样的,又P2是先到达就绪队列的,所以先调度P2

在这里插入图片描述

例题(抢占式的短作业优先调度算法)

此时调度算法执行的两个时间点:一个是就绪队列改变,此时会比较新到达的进程的剩余时间比当前运行的进程剩余时间。一个是进程完成时,此时会从就绪队列中选择剩余时间最少的上处理机

在这里插入图片描述
运算结果
在这里插入图片描述

注意

在这里插入图片描述

FCFS和SJF两种算法的思考

等待时间长=到达时间早
在这里插入图片描述

高响应比优先

不会导致饥饿
在这里插入图片描述

例题

在这里插入图片描述

小结

这几种调度算法不关系响应时间,也不区分认任务的紧急程度=交互性糟糕
如果一个系统不关注响应时间,并且不区分任务的紧急程度,会导致用户交互性糟糕的原因如下:

  • 用户体验差:如果系统不考虑响应时间,用户可能需要等待很长时间才能得到反馈,这会让用户感到沮丧和不满。
  • 效率低下:不区分任务紧急程度可能导致关键任务被延迟,影响整体工作效率。
    缺乏优先级管理:系统应能根据任务的重要性和紧迫性进行合理排序,否则可能导致资源浪费和目标错位。
  • 存在交互机会少,自然也会使得交互性很糟糕

早期的批处理系统是一种自动处理程序和数据的方式,用户提交一批作业后,不再干预,由系统自动运行
在这里插入图片描述

这篇关于操作系统-调度算法-1(先来先服务算法 短作业优先 高响应比优先 )的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/664712

相关文章

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,