2.7、进程调度的时机、切换与过程、方式
1、进程调度的时机
进程调度\color{red}进程调度进程调度(低级调度),就是按照某种算法从就绪队列中选择一个进程为其分配处理机
进程在操作系统内核程序临界区\color{red}操作系统内核程序临界区操作系统内核程序临界区中不能\color{red}不能不能进行调度与切换 √
(2012 年联考真题)进程处于临界区\color{red}临界区临界区时不能\color{red}不能不能进行处理机调度 ❌
临界资源
:一个时间段内只允许一个进程使用的资源。
- 各进程需要互斥地\color{red}互斥地互斥地访问临界资源。
临界区
:访问临界资源的那段代码。
内核程序临界区\color{red}内核程序临界区内核程序临界区一般是用来访问某种内核数据结构\color{red}某种内核数据结构某种内核数据结构的,
- 比如进程的就绪队列(由各就绪进程的
PCB
组成)
若还没有退出内核程序临界区(还没解锁)就进行进程调度(访问就绪队列),
-
但是进程调度的相关程序也需要访问就绪队列,
但此时就绪队列被锁住了,因此又无法顺利进行进程调度
若此时进程访问的是普通的临界资源,例如:打印机
在打印机打印完成之前,进程一直处于临界区内,临界资源不会解锁。
- 但打印机又是慢速设备,此时如果一直不允许进程调度的话就会导致
CPU
一直空闲
普通I临界区访问的临界资源不会直接影响操作系统内核的管理工作。
- 因此在访问普通临界区时可以进行调度与切换。
2、进程调度的方式
有的系统中,只允许进程主动放弃处理机
有的系统中,进程可以主动放弃处理机,
- 当有更紧急的任务需要处理时,也会强行剥夺处理机(被动放弃)
2.1、非剥夺方式(非抢占方式)
非剥夺调度方式\color{red}非剥夺调度方式非剥夺调度方式,又称非抢占方式\color{red}非抢占方式非抢占方式。
- 即,只允许进程主动放弃处理机。
在运行过程中即便有更紧迫的任务到达,当前进程依然会继续使用处理机,
- 直到该进程终止或主动要求进入阻塞态。
实现简单,系统开销小但是无法及时处理紧急任务,适合于早期的批处理系统
2.2、剥夺调度方式(抢占方式)
剥夺调度方式\color{red}剥夺调度方式剥夺调度方式,又称抢占方式\color{red}抢占方式抢占方式。
- 当一个进程正在处理机上执行时,如果有一个更重要或更紧迫的进程需要使用处理机,则立即暂停正在执行的进程,将处理机分配给更重要紧迫的那个进程。
可以优先处理更紧急的进程,也可实现让各进程按时间片轮流执行的功能(通过时钟中断)。
- 适合于分时操作系统、实时操作系统
3、进程的切换与过程
“狭义的进程调度” 与 “进程切换” 的区别
“狭义的进程调度” 与 “进程切换” 的区别:
狭义的进程调度\color{red}狭义的进程调度狭义的进程调度指的是从就绪队列中选中一个要运行的进程\color{red}选中一个要运行的进程选中一个要运行的进程。
- 这个进程可以是刚刚被暂停执行的进程,也可能是另一个进程,后一种情况就需要进程切换
进程切换\color{red}进程切换进程切换是指一个进程让出处理机,由另一个进程占用处理机的过程。
广义的进程调度\color{red}广义的进程调度广义的进程调度包含了选择一个进程和进程切换两个步骤。
进程切换的过程主要完成了:
-
对原来运行进程各种数据的保存(信息一般保存在
PCB
中) -
对新的进程各种数据的恢复
(如:程序计数器、程序状态字、各种数据寄存器等处理机现场信息,这些信息一般保存在进程控制块)
注意:进程切换是有代价的\color{red}进程切换是有代价的进程切换是有代价的
- 因此如果过于频繁的进行进程调度、切换,必然会使整个系统的效率降低,使系统大部分时间都花在了进程切换上,而真正用于执行进程的时间减少。
4、整体框架
相关文章:
![](https://img-blog.csdnimg.cn/img_convert/1bb1df599e3b49616f7a33aa7c292080.png)
2.7、进程调度的时机、切换与过程、方式
1、进程调度的时机 进程调度\color{red}进程调度进程调度(低级调度),就是按照某种算法从就绪队列中选择一个进程为其分配处理机 进程在操作系统内核程序临界区\color{red}操作系统内核程序临界区操作系统内核程序临界区中不能\color{red}不能…...
![](https://www.ngui.cc/images/no-images.jpg)
工程管理系统源码+项目说明+功能描述+前后端分离 + 二次开发
工程项目各模块及其功能点清单 一、系统管理 1、数据字典:实现对数据字典标签的增删改查操作 2、编码管理:实现对系统编码的增删改查操作 3、用户管理:管理和查看用户角色 4、菜单管理:实现对系统菜单的增删改查操…...
![](https://www.ngui.cc/images/no-images.jpg)
ESP32S3系列--SPI从机驱动详解(一)
一、目的 在之前的博文中《ESP32S3系列--SPI主机驱动详解(一)》、《ESP32S3系列--SPI主机驱动详解(二)》我们详细讲解了ESP32S3上的SPI外设如何工作在主机模式并通过代码的形式帮助大家理解。 本篇我们将介绍SPI外设工作在从机模式下的使用知识点。 二、介绍 参考资料 http…...
![](https://www.ngui.cc/images/no-images.jpg)
【实战篇】移动端H5网页在ios滑动不流畅和禁止缩放问题
问题描述:移动端H5网页在ios滑动不流畅和禁止缩放问题 最近开发小程序,有一个富文本展示页面使用的是<webview>H5网页嵌入的,当你用 overflow-y:scroll 属性的时候,内容超出容器溢出滚动的效果很迟顿,特别是在IOS系统中,而且页面还会缩放。 解决方案: 1…...
![](https://img-blog.csdnimg.cn/2f37b5089b914c0894b9d657f64d9a6d.png)
12 循环神经网络(基础篇) Basic RNN
文章目录问题引入关于权重权重共享RNN CellRNN原理RNN计算过程代码实现RNN Cell维度说明代码RNN维度说明NumLayers说明计算过程代码参考实例问题分析多分类问题代码RNN CellRNN改进Embedding网络结构Embedding说明Linear说明代码课程来源: 链接课程文本参考…...
![](https://img-blog.csdnimg.cn/img_convert/197ea7cb0bc8bbc48f4f9650aedf8445.png)
【C语言必经之路——第11节】初阶指针(2)
五、指针的运算1、指针与整数相加减看一下下面的代码:#include<stdio.h> int my_strlen(char* str) {int count0;while(*str!\0){count;str;//指针加减整数}return count; } int main() {int lenmy_strlen("abcdef");printf("%d\n",len);…...
![](https://www.ngui.cc/images/no-images.jpg)
SpringBoot学习(1)第一个SpringBoot程序
之前的SpringMVc就不在记录了,好像时间不太够了,但是springmvc作为javaweb的升级学一学对于springboot还是有较大的帮助的。 首先我们需要引入依赖,但是请注意,其中的一个不算是依赖,写法有所不同 首先需要引入 <…...
![](https://img-blog.csdnimg.cn/c267283799e948449b23299831e93227.jpeg)
什么是热迁移?90%的企业都理解错误
科技的发展,新冠的冲击,让市场竞争愈发激烈。尽管云计算服务为企业免除了基础硬件的建设和维护成本,当企业需要进行业务跨架调整、升级维护、环境测试等场景而进行云迁移,其过程中所带来的停机时间,就变得尤为头疼了。…...
![](https://www.ngui.cc/images/no-images.jpg)
Scratch少儿编程案例-丝滑版贪吃蛇
专栏分享 点击跳转=>Unity3D特效百例点击跳转=>案例项目实战源码点击跳转=>游戏脚本-辅助自动化点击跳转=>Android控件全解手册点击跳转=>Scratch编程案例👉关于作者...
![](https://www.ngui.cc/images/no-images.jpg)
Linux系统之网卡子接口配置方法
Linux系统之网卡子接口配置方法一、本地系统环境检查1.检查系统版本2.检查系统内核版本3.检查本地IP地址二、网卡子接口介绍1.网卡子接口简介2.网卡子接口的优点3.网卡子接口的缺点三 加载802.1q 模块1.查看系统802.1q 模块信息2.加载802.1q 模块3.检查802.1q 模块加载状态四、…...
![](https://img-blog.csdnimg.cn/876d92dbfa6d48c98dac72c35498c52c.jpeg#pic_center)
2023上半年软考中级系统集成项目管理工程师2月25日开班
系统集成项目管理工程师是全国计算机技术与软件专业技术资格(水平)考试(简称软考)项目之一,是由国家人力资源和社会保障部、工业和信息化部共同组织的国家级考试,既属于国家职业资格考试,又是职…...
![](https://img-blog.csdnimg.cn/img_convert/6dff9792bbadd42690dcd427fc09f9f5.png)
YOLO-V5轻松上手
之前介绍了YOLO-V1~V4版本各做了哪些事以及相较于之前版本的改进。有的人或许会想“直接学习最近版本的算法不好吗”,在我看来,每一个年代的版本/算法都凝聚着当年学术界的智慧,即便是它被淘汰了也依旧有值得思考的地方,或是可以使…...
![](https://www.ngui.cc/images/no-images.jpg)
CSS的优先级理解
权重 的 4个等级定义我们把特殊性分为4个等级,每一个等级代表一类选择器,每个等级的值相加得出选择器的权重。4个等级的定义如下:第一等级:代表内联样式,如style"",权值为 1000第二等级ÿ…...
![](https://img-blog.csdnimg.cn/118d8290a893420cb421b194577bf17d.png)
前端工程师leetcode算法面试必备-二分搜索算法(中)
一、前言 二分搜索算法本身并不是特别复杂,核心点主要集中在: 有序数组:指的是一个递增或者递减的区间(特殊情况如:【852. 山脉数组的峰顶索引】); 中间数:用来确定搜索目标落在左…...
![](https://img-blog.csdnimg.cn/49f93b943f044785a173f2051e1277d3.png)
【数据库】MySQL 单表查询,多表查询
目录 单表查询 一,创建表worker 1,创建表worker的sql代码如下: 2,向worker表中插入信息 二, 按要求进行单表查询 1、显示所有职工的基本信息。 2、查询所有职工所属部门的部门号,不显示重复的部门号。 …...
![](https://img-blog.csdnimg.cn/e5ba8b04b1b741ad9846701afabc3c18.jpeg)
【c++】vector实现(源码剖析+手画图解)
vector是我接触的第一个容器,好好对待,好好珍惜! 目录 文章目录 前言 二、vector如何实现 二、vector的迭代器(原生指针) 三、vector的数据结构 图解: 四、vector的构造及内存管理 1.push_back() …...
![](https://img-blog.csdnimg.cn/38675a718a1b460bba395ce5220c71f3.png)
VScode查看python f.write()的文件乱码
VScode查看python f.write()的文件乱码 在使用 VScode 编写 python 代码, print(),汉字正常显示, 使用 with open()as f: f.write()文件后, 在 …...
![](https://img-blog.csdnimg.cn/img_convert/a3bae92ca6b459bfde8e067e4eb9091b.webp?x-oss-process=image/format,png)
excel应用技巧:如何用函数制作简易抽奖动图
利用INDEX函数和随机整数函数RANDBETWEEN配合,在Excel中做一个简单的抽奖器,可以随机抽取姓名或者奖品。有兴趣的伙伴可以做出来试试,撞撞2023年好运气。每次年会大家最期待的就是抽奖环节。为了看看自己今年运气怎么样,会不会获奖…...
![](https://csdnimg.cn/release/blog_editor_html/release2.2.2/ckeditor/plugins/CsdnLink/icons/icon-default.png?t=N0U7)
CSI Tool 安装及配置记录
一、Ubuntu安装 1.下载Ubuntu 首先安装Ubuntu 14.04 LTS 64位下载地址(页面中第一个链接) 2.制作启动盘(注意备份) 可以使用官方的工具Rufus,下载地址:https://rufus.ie/ 打开Rufus,先备份…...
![](https://www.ngui.cc/images/no-images.jpg)
华为OD机试 - 最低位排序(Python)| 真题+思路+代码
最低位排序 题目 给定一个非空数组(列表),起元素数据类型为整型, 请按照数组元素十进制最低位从小到大进行排序, 十进制最低位相同的元素,相对位置保持不变, 当数组元素为负值时,十进制最低为等同于去除符号位后对应十进制值最低位。 输入 给定一个非空数组(列表) 其…...
![](https://www.ngui.cc/images/no-images.jpg)
C#开发的OpenRA使用TrimExcess方法
C#开发的OpenRA使用TrimExcess方法 当你在细看OpenRA的代码,就会发现在下面这段代码添加了一个方法: foreach (var nodes in levels) nodes.TrimExcess(); 在上面代码里遍历整个节点列表,把所有节点都调用TrimExcess方法处理一下, 这样做的意义何在?为什么我们在一般的代码…...
![](https://img-blog.csdnimg.cn/img_convert/2f7c0dfec9f9470e58ad261a0bec4265.png)
ImageMagick任意文件读取漏洞(CVE-2022-44268)
0x00 前提 前几天爆出一个 ImageMagick 漏洞 ,可以造成一个任意文件读取的危害比较可观,最近有时间来复现学习一下 主要是影响的范围很大,很多地方都有这个问题,需要来学习一下 0x01 介绍 ImageMagick 是一个免费的开源软件套…...
![](https://www.ngui.cc/images/no-images.jpg)
第十九篇 ResNet——论文翻译
文章目录 摘要1 引言2 相关工作3 深度残差学习3.1 残差学习3.2 快捷恒等映射3.3 网络架构3.4 实现4 实验4.1 ImageNet 分类4.2 CIFAR-10 和分析4.3 PASCAL 和 MS COCO 上的物体检测🐇🐇🐇🐇🐇🐇 🐇 欢迎阅读 【AI浩】 的博客🐇 👍 阅读完毕,可以动动小手赞一…...
![](https://img-blog.csdnimg.cn/img_convert/0ba4eb99ed437109813d0210af657d62.png)
RiProRiProV2主题美化顶部增加一行导航header导航通知
背景: 有些网站的背景顶部有一行罪行公告,样式不错,希望自己的网站也借鉴过来,本教程将指导如何操作,并调整成自己想要的样式。 比如网友搭的666资源站 xd素材中文网...
![](https://img-blog.csdnimg.cn/0b980ea9127b41d4a9a158a0313a3fbd.png)
RT-Thread MSH_CMD_EXPORT分析
RT-Thread MSH_CMD_EXPORT分析 1. 源码分析 在rt-thread中,使用FinSH,可以支持命令行。在源码中,使用MSH_CMD_EXPORT导出函数到对应命令。 extern void rt_show_version(void); long version(void) {rt_show_version();return 0; } MSH_CM…...
![](https://csdnimg.cn/release/blog_editor_html/release2.2.3/ckeditor/plugins/CsdnLink/icons/icon-default.png?t=N176)
电脑麦克风没声音怎么办?这3招就可以解决!
最近有用户在使用电脑麦克风进行视频录制时,发现麦克风没有声音。这是什么原因?电脑麦克风没有声音怎么办?关于解决方案,我专门整理了三种方法来帮你们,一起来看看吧! 操作环境: 演示机型&#…...
![](https://img-blog.csdnimg.cn/4e235f7eed1b4001b0ae752507cadeb3.png)
【C++】运算符重载
运算符重载 C为了增强代码的可读性引入了运算符重载,运算符重载是具有特殊函数名的函数,也具有其返回值类型,函数名以及参数列表。其返回值类型和参数列表与普通的函数类型。 函数名字为:关键字operator后面接需要重载的运算符号…...
![](https://img-blog.csdnimg.cn/76ba08b36d11480999209683f3fa017d.png)
什么是眼图?(扫盲向)
什么是眼图?(扫盲向) Ref: What’s eye diagram? 1 基础图示 眼图 2 用途 常用于评估差分链路中的信号传输质量 "眼睛"张得越开,链路信号质量越好 3 观测原理 眼图是传输信号序列在时域上的叠加 4 观测参数 4…...
![](https://img-blog.csdnimg.cn/2adcb9add60c446fa9a0ae69e6b73f56.png)
【C++】类与对象(二)
前言 在前一章时我们已经介绍了类与对象的基本知识,包括类的概念与定义,以及类的访问限定符,类的实例化,类的大小的计算,以及C语言必须传递的this指针(C中不需要我们传递,编译器自动帮我们实现&…...
![](https://img-blog.csdnimg.cn/8221f110d49f41c58834e3d0baf927d0.jpeg#pic_center)
【软考】系统集成项目管理工程师(二十一)项目收尾管理
1. 项目验收2. 项目总结3. 系统维护4. 项目后评价补充:人员转移和资源遣散广义的系统集成项目收尾管理工作通常包含四类典型的工作:项目验收工作、项目总结工作、系统维护工作 以及 项目后评价工作,此外项目团队成员的后续工作也应在收尾管理时妥善安排;狭义的系统集成项目…...
![](https://img-blog.csdnimg.cn/img_convert/19af76b01fcaf3da54dd4e2d2702d577.png)
做室内设计的网站/ueeshop建站费用
五、网站模板替换教程为了接下来的截图更好看,小编已经给网站增加了若干几个栏目,并添加若干内容。因为默认模板的首页有首页头条、首页幻灯片等推荐位,所以小编推荐几篇内容并更新缓存生成首页之后,网站的截图如下:系…...
![](http://pic002.cnblogs.com/images/2010/133128/2010113015530648.png)
长沙知名网站推广/seo优缺点
最近在网上看到一篇介绍android window的requestWindowFeature()的使用方法,共享出来大家学习学习 requestWindowFeature(Window.FEATURE_LEFT_ICON);setContentView(R.layout.dialog_activity);getWindow().setFeatureDrawableResource(Window.FEATURE_LEFT_ICON,…...
![](/images/no-images.jpg)
网站根目录是哪个文件夹/网页设计制作教程
世界上最成功的人一开始是个程序员。在1974年,Bill Gates为Altair 8800写了一个4K的编译器,今天,他创立的Microsoft用Windows操作系统和Microsoft Office, Microsoft Home等产品统治了PC软件市场。Bill成了世界首富,他的个人财产今…...
![](/images/no-images.jpg)
wordpress商城怎么样/100%上热门文案
2020/7/28 依旧是和sql有着不解之缘的一天 总结一下在python中用sql语句的一些汇总 insertinsert into tablename(column1,column2...) values(value1,value2...) insert into tablename(column1,column2...) values(%s,%s...)---->然后你要传数据到这个里面去࿰…...
![](https://img-blog.csdnimg.cn/759beae483b34c5cb8316596a56f8b66.png)
找网站做q币/线上推广策略
代码块概述 ●代码块是类的5大成分之一(成员变量、构造器,方法,代码块,内部类),定义在类中方法外。 ●在ava类下,使用{}括起来的代码被称为代码块。 代码块分为 静态代码块: 格式:static{ 特点:需要通过static关键字修…...
![](/images/no-images.jpg)
网站接入查询/seo优化推广业务员招聘
《信息技术试讲《计算机信息加工的一般过程》教案》由会员分享,可在线阅读,更多相关《信息技术试讲《计算机信息加工的一般过程》教案(4页珍藏版)》请在人人文库网上搜索。1、信息技术试讲计算机信息加工的一般过程教案一、教学目标【知识与技能】理解信…...