操作系统-调度算法-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

相关文章

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自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

关于DNS域名解析服务

《关于DNS域名解析服务》:本文主要介绍关于DNS域名解析服务,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录DNS系统的作用及类型DNS使用的协议及端口号DNS系统的分布式数据结构DNS的分布式互联网解析库域名体系结构两种查询方式DNS服务器类型统计构建DNS域

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过