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

处理机调度的概念,层次联系以及七状态模型

1.基本概念

当有一堆任务要处理,但由于资源有限,这些事情没法同时处理。
这就需要确定某种规则来决定处理这些任务的顺序,这就是“调度”研究的问题。

2. 三个层次

1.高级调度(作业调度)

高级调度(作业调度):按一定的原则从外存的作业后备队列中挑选一个作业调入内存,并创建进程。

  1. 作业:一个具体的任务
  2. 用户向系统提交一个作业 =用户让操作系统启动一个程序(来处理一个具体的任务)
  3. 每个作业只调入一次,调出一次。
  4. 作业调入时会建立PCB,调出时才撤销PCB。
2.中级调度(内存调度)

中级调度(内存调度):按照某种策略决定将哪个处于挂起状态的进程重新调入内存。

  1. 内存不够时,可将某些进程的数据调出外存。
  2. 等内存空闲或者进程需要运行时再重新调入内存。
  3. 暂时调到外存等待的进程状态为挂起状态
  4. 被挂起的进程PCB会被组织成挂起队列
  5. 一个进程可能会被多次调出、调入内存,因此中级调度发生的频率要比高级调度更高。
3.低级调度(进程调度)

低级调度(进程调度/处理机调度):按照某种策略从就绪队列中选取一个进程,将处理机分配给它。

  1. 进程调度是操作系统中最基本的一种调度,在一般的操作系统中都必须配置进程调度。
  2. 进程调度的频率很高,一般几十毫秒一次。

3.三层调度的联系,对比

在这里插入图片描述

4.进程的挂起态

暂时调到外存等待的进程状态为挂起状态(挂起态,suspend)
挂起态又可以进一步细分为就绪挂起、阻塞挂起两种状态

5.七状态模型

五状态模型到七状态模型
在这里插入图片描述

  1. 注意“挂起”和“阻塞”的区别,两种状态都是暂时不能获得CPU的服务,但挂起态是将进程映像调到外存去了,而阻塞态下进程映像还在内存中。
  2. 有的操作系统会把就绪挂起、阻塞挂起分为两个挂起队列,甚至会根据阻塞原因不同再把阻塞挂起进程进一步细分为多个队列。
http://www.lryc.cn/news/182482.html

相关文章:

  • PS 图层剪贴蒙版使用方法
  • 总结1008
  • 软件工程从理论到实践客观题汇总(头歌第九章至第十七章)
  • ubuntu与win之间共享文件夹
  • flink处理函数--副输出功能
  • Java数据结构————队列
  • 办公网络构建
  • 单层神经网络
  • htb-cozyhosting
  • 网络安全渗透测试工具之skipfish
  • 【Rust】文件系统
  • mysql双主双从读写分离
  • postgresql-物化视图
  • 多层神经网络和激活函数
  • Visual Studio Code键盘快捷键大全
  • 新手学习笔记-----⽂件操作
  • LeetCode 251:展开二维向量
  • 练[BSidesCF 2020]Had a bad day
  • 第十五章 类和对象——友元
  • 【数仓精品理论分析】能不能学大数据?
  • java复习-多态性
  • 美团外卖优惠券小程序 美团优惠券微信小程序 自带流量主模式 带教程
  • 编写IDEA插件,实现根据现有代码生成流程图
  • 王杰国庆作业day6
  • 【C语言】循环结构程序设计 (详细讲解)
  • Spring的注解开发-注解原理解析-xml方式/注解方式组件扫描
  • 导出视频里的字幕
  • 【KingbaseES】银河麒麟V10 ARM64架构_安装人大金仓数据库KingbaseES_V8R6(CentOS8)
  • 【Vue】Vuex详解,一文读懂并使用Vuex
  • 第三章 C程序设计