当前位置: 首页 > news >正文

第二章 进程与线程 十、调度算法1(先来先服务、短作业优先、最高响应比优先)

目录

一、先来先服务算法

1、算法思想

2、算法规则

3、用于作业/进程调度

4、是否可抢占?

5、优缺点

优点:

缺点:

6、是否会导致饥饿

7、例子

二、短作业优先算法

1、算法思想

2、算法规则

3、用于作业/进程调度

4、是否可抢占?

5、优缺点

优点:

缺点:

6、是否会导致饥饿

7、例子

(1)非抢占式

(2)抢占式

三·、最高响应比优先算法

1、算法思想

2、算法规则

3、用于作业/进程调度

4、是否可抢占?

5、优缺点

6、是否会导致饥饿

7、例子

注意:


一、先来先服务算法

1、算法思想

主要从“公平”的角度考虑(类似于我们生活中排队买东西的例子)

2、算法规则

按照作业/进程到达的先后顺序进行服务

3、用于作业/进程调度

用于作业调度时,考虑的是哪个作业先到达后备队列;

用于进程调度时,考虑的是哪个进程先到达就绪队列。

4、是否可抢占?

非抢占式的算法

5、优缺点

优点:

公平、算法实现简单

缺点:

排在长作业(进程)后面的短作业需要等待很长时间,带权周转时间很大,对短作业来说用户体验不好。

即,FCFS算法对长作业有利,对短作业不利(Eg :排队买奶茶.)

6、是否会导致饥饿

不会导致饥饿

7、例子

(1)根据先来先服务的规则,调度顺序是P1,P2,P3,P4。

二、短作业优先算法

1、算法思想

追求最少的平均等待时间,最少的平均周转时间、最少的平均带权周转时间。

2、算法规则

最短的作业或进程先得到服务(所谓“最短”,是指要求服务时间最短)

3、用于作业/进程调度

即可用于作业调度,也可用于进程调度。

用于进程调度时称为“短进程优先(SPF, Shortest Process First)算法”。

4、是否可抢占?

SJF和SPF是非抢占式的算法。

但是,也有抢占式的版本――最短剩余时间优先算法( SRTN, Shortest Remaining Time Next)

5、优缺点

优点:

“最短的”平均等待时间、平均周转时间。

缺点:

不公平。对短作业有利,对长作业不利。可能产生饥饿现象。另外,作业/进程的运行时间是由用户提供的,并不一定真实,不一定能做到真正的短作业优先。  

6、是否会导致饥饿

会。

如果源源不断地有短作业/进程到来,可能使长作业/进程长时间得不到服务,产生“饥饿”现象。

如果一直得不到服务,则称为“饿死”。

7、例子

(1)非抢占式

(2)抢占式

三·、最高响应比优先算法

1、算法思想

要综合考虑作业/进程的等待时间和要求服务的时间

2、算法规则

在每次调度时先计算各个作业/进程的响应比,选择响应比最高的作业/进程为其服务。

3、用于作业/进程调度

即可用于作业调度,也可用于进程调度。

4、是否可抢占?

非抢占式的算法。

因此只有当前运行的作业/进程主动放弃处理机时,才需要调度,才需要计算响应比。

5、优缺点

综合考虑了等待时间和运行时间(要求服务时间)

等待时间相同时,要求服务时间短的优先(SJF的优点)

要求服务时间相同时,等待时间长的优先(FCFS的优点)

对于长作业来说,随着等待时间越来越久,其响应比也会越来越大,从而避免了长作业饥饿的问题

6、是否会导致饥饿

不会

7、例子

每次进程结束后都要重新计算响应比。

注意:

(1)这几种算法主要关心对用户的公平性、平均周转时间、平均等待时间等评价系统整体性能的指标,但是不关心“响应时间”,也并不区分任务的紧急程度,因此对于用户来说,交互性很糟糕。

(2)因此这三种算法一般适合用于早期的批处理系统,当然,FCFS算法也常结合其他的算法使用,在现在也扮演着很重要的角色。
 

http://www.lryc.cn/news/168809.html

相关文章:

  • windows平台 git bash使用
  • Linux系统之安装uptime-kuma服务器监控面板
  • 计算机组成原理——基础入门总结(一)
  • 批量获取CSDN文章对文章质量分进行检测,有助于优化文章质量
  • 从一到无穷大 #17 Db2 Event Store,A Purpose-Built IoT Database Engine
  • 9月16日,每日信息差
  • 准备篇(二)Python 教程
  • HTML+CSS画一个卡通中秋月饼
  • echarts的折线图,在点击图例后,提示出现变化,不报错。tooltip的formatter怎么写
  • C++中的auto是一个关键字,用于在编译时自动推导变量的类型
  • VUE build:gulp打包:测试、正式环境
  • 1.使用turtle换一个五环2.设计这样一个程序:输入一个数字 判断它是不是一个质数
  • C语言希尔排序
  • KubeSphere 在互联网医疗行业的应用实践
  • 物联网:用python调入机器学习分析物联网数据入侵检测模块
  • 使用scss简化媒体查询
  • win部署CRM
  • Linux命令200例:dip用于用户与远程主机建立通信连接
  • 【每日一题】981. 基于时间的键值存储
  • IMU姿态解算,从IMU数据中计算旋转、速度、位置,IMU测量的原理
  • 【Qt-17】Qt调用matlab生成的dll库
  • css经典面试题(二)
  • jira搜索search issue条目rest实用脚本
  • 《C++ primer plus》精炼(OOP部分)——对象和类(5)
  • 钉钉旧版服务端SDK支持异步方法的升级改造
  • 【C语言】【数据存储】用%d打印char类型数据,猜结果是啥
  • 算法——双指针
  • 【PowerQuery】Excel的PowerQuery按需刷新
  • Django REST Farmowork初探
  • 【flink进阶】-- Flink kubernetes operator 版本升级