57 - 深入解析任务调度

news/2024/10/19 12:36:02/

---- 整理自狄泰软件唐佐林老师课程

文章目录

  • 1. 问题
    • 1.1 思考
    • 1.2 实例分析:问题分析及解决
  • 2. 深入讨论
    • 2.1 任务调度的定义
    • 2.2 关于调度算法的分类
    • 2.3 什么时候进行任务调度
    • 2.4 任务的分类
    • 2.5 关于优先级调度
    • 2.6 问题
    • 2.7 调度算法的终极目标
    • 2.8 课后扩展

1. 问题

  • 系统运行后,下面的任务将如何进行?

在这里插入图片描述

【参看链接】:57 - 深入解析任务调度 / 00

在这里插入图片描述

1.1 思考

  • 任务B执行了吗?如果执行了,那么为什么看不出输出?

【参看链接】:57 - 深入解析任务调度 / 01

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.2 实例分析:问题分析及解决

在这里插入图片描述

  • 保证任务时间片 大于 两个时间片
    • 时间片:两次时钟中断之间的时间间隔

【参看链接】:57 - 深入解析任务调度 / 02

在这里插入图片描述

2. 深入讨论

2.1 任务调度的定义

  • 当多个任务处于就绪状态,而处理器只有一个时,操作系统就必须 决定哪一个任务先执行
  • 操作系统中做出这种决定的部分成为 调度器,调度器使用的算法称为 调度算法

2.2 关于调度算法的分类

  • 非抢占式调度算法
    任务持续执行直到阻塞(如等待事件发生)或自愿让出执行权
  • 抢占式调度算法
    任务每次执行的时间固定,时间一到被迫让出执行权

2.3 什么时候进行任务调度

  • 当任务退出时(运行结束)
  • 当新任务创建时
  • 当时钟中断发生时
  • 当任务I/O中断发生时
  • ……

2.4 任务的分类

  • 计算密集型任务
    任务大部分时间在使用处理器运算(如:科学运算)
  • I/O密集型任务
    任务大部分时间用于等待I/O操作(如:文件操作)

2.5 关于优先级调度

  • 优先级用于反映任务的重要程度
  • 优先级越高,任务越容易获得执行的机会
    • 越多的执行时间(计算机密集型任务)
    • 越快的响应速度(I/O密集型任务)

2.6 问题

  • 如何处理高优先级任务对执行时间和响应时间的需求?

2.7 调度算法的终极目标

  • 公平公正,每个任务都能被执行
  • 最大化处理器利用率,保持处理器时始终忙碌
  • 最小化任务从执行到完成的时间
  • 最快响应时间,快速响应用户交互
  • ……

2.8 课后扩展

  • FCFS先到先服务调度算法(First Come First Served)
  • SJF最短执行时间调度算法(Shortest Job First)
  • RR轮询调度算法(Round Robin)
  • MQ多级队列调度算法(Multilevel Queue)

http://www.ppmy.cn/news/27805.html

相关文章

【女程序员进大厂面试经验】

*那些犹豫想做技术又不敢的女生一定不要胆怯,就认准了这条路坚持走下去。大三的学生已经可以开始投简历、寻找面试机会了。先说一下我的情况吧!我是郑州一双普通本科的女大学生,刚找工作的时候也很迷茫。同班的女生有做产品的、有做前端的、还…

SpringBoot搭建SpringMVC项目

前言据我的了解,现在不管是大公司或是小公司,如果使用java开发一个web项目,大部分都会选择使用SpringBoot,关于Springboot的好处,就不在这里过多赘述,总之Springboot有一套完整的生态,从项目构建…

题解 # 二维矩阵最大矩形问题#

题目&#xff1a; 小明有一张N*M的方格纸&#xff0c;且部分小方格中涂了颜色&#xff0c;部分小方格还是空白。 给出N (2<Ns30)和M(2sMs30)的值&#xff0c;及每个小方格的状态(&#xff08;被涂了颜色小方格用数字1表示&#xff0c;空白小方格用数字0表示)&#xff1b; 请…

华为OD机试真题Java实现【汽水瓶】真题+解题思路+代码(20222023)

汽水瓶 有这样一道智力题:“某商店规定:三个空汽水瓶可以换一瓶汽水。小张手上有十个空汽水瓶,她最多可以换多少瓶汽水喝?”答案是 5 瓶,方法如下:先用 9 个空瓶子换3瓶汽水,喝掉 3 瓶满的,喝完以后 4 个空瓶子,用 3 个再换一瓶,喝掉这瓶满的,这时候剩 2 个空瓶子。…

springboot 批量下载附件接口,打包成zip

前言 springboot是很流行的框架&#xff0c;文件下载接口也是开发中很简单常见的接口&#xff0c;但是批量附件下载呢&#xff1f;将多个附件打包成zip呢&#xff1f;虽然确实是很简单的一个事情&#xff0c;但是写还是要花点时间来捋一下&#xff0c;前几天刚做过这个需求&am…

【华为OD机试模拟题】用 C++ 实现 - 数字的排列(2023.Q1)

最近更新的博客 【华为OD机试模拟题】用 C++ 实现 - 分积木(2023.Q1) 【华为OD机试模拟题】用 C++ 实现 - 吃火锅(2023.Q1) 【华为OD机试模拟题】用 C++ 实现 - RSA 加密算法(2023.Q1) 【华为OD机试模拟题】用 C++ 实现 - 构成的正方形数量(2023.Q1) 【华为OD机试模拟…

该学会是自己找bug了(vs调试技巧)

前言 &#x1f388;个人主页:&#x1f388; :✨✨✨初阶牛✨✨✨ &#x1f43b;推荐专栏: &#x1f354;&#x1f35f;&#x1f32f; c语言初阶 &#x1f511;个人信条: &#x1f335;知行合一 &#x1f349;本篇简介:>:介绍c语言初阶的最后一篇.有关调试的重要性. 金句分享…

WebDAV之π-Disk派盘+Cloud Player

Cloud Player 支持WebDAV方式连接π-Disk派盘。 推荐一款云媒体播放器是存储在常见云平台中的内容的通用播放器。 Cloud Player云媒体播放器是存储在常见云平台中的内容的通用播放器,无需将其下载到设备。支持以下云平台:Google Drive、DropBox、One Drive、WebDav等。此外,…