【重学计算机】操作系统D2章:处理器管理
1. 指令与处理器模式
- 指令执行周期:取指、译码、执行
- 指令分类(根据权限)
- 特权指令:只能被操作系统内核使用(启动IO,置PC值)
- 非特权指令:所有程序都能使用
- 处理器模式:
- 共有四种:0内核模式,1系统调用,2共享库程序,3用户模式
- 一般来说:只有0内核模式(能执行全部指令)和3用户模式(只能执行非特权指令)
- 模式切换:
- 用户模式 --> 内核模式(系统调用、异常、响应中断)
- 内核模式 --> 用户模式(中断返回指令)
2. 中断
- 概念:
- 操作系统是中断驱动的。即中断是激活操作系统的唯一方式
- 广义中断:停止CPU正在执行的进程,转而执行中断处理程序,处理完后返回原进程或调度新进程
- 狭义中断:源于处理器之外的中断事件,IO中断、时钟中断、外部信号中断
- 中断源:
- 处理器硬件故障中断事件:内存故障
- 程序性中断事件:除0异常、缺页异常
- 自愿性中断事件:系统调用
- IO中断事件:IO完成
- 外部中断事件:鼠标点击
- 中断系统:
- 实现:硬件完成中断响应,软件完成中断处理

- 中断装置:
- 处理器外中断:由中断控制器实现
- 处理器内中断(陷阱):由指令控制逻辑实现
- 系统调用(系统陷阱):执行陷入指令时直接触发,即系统陷阱
- 中断处理流程

- 多中断处理:中断屏蔽、中断优先级、中断嵌套
3. 进程
- 进程:操作系统进行资源分配和调度的独立单位
- 进程解剖:OS管理进程的数据结构P + 内存代码 + 内存数据 + 通用寄存器R + PSW
- 进程状态:


- 进程数据:
- 进程控制块PCB:是OS用于记录进程状态和环境信息的数据结构
- 标识信息:进程标识(进程标识号、进程组标识号)
- 现场信息:用户可见寄存器内容、控制/状态寄存器内容、栈指针内容
- 控制信息:进程调度信息、进程组成信息、队列指引元、通信相关、进程特权信息、处理器使用信息、资源清单信息
- 进程映像:某一时刻进程的内容及执行状态集合
- 进程控制块、进程程序块、进程数据块、核心栈

- 进程上下文:进程执行的环境支持(CPU现场、Cache中的执行信息)
- 用户级、寄存器级、系统级
- 进程控制块PCB:是OS用于记录进程状态和环境信息的数据结构
- 进程的管理
- 进程实现的队列模型

- 进程控制流程
- 进程创建:进程表增加一项,申请PCB并初始化,生成标识,建立映像,分配资源,移入就绪队列
- 进程撤销:从队列中移除,归还响应资源。。。
- 进程阻塞:保存现场,修改PCB,移入等待队列
- 进程唤醒:从等待队列移出,修改PCB,进入就绪队列
- 进程挂起:修改进程状态并出入相关队列,收回内存等资源送至对换区
- 进程激活:分配内存,修改状态并出入相关队列
- 原语
- 概念:由若干指令构成的完成某种特定功能,有原子性
- 应用:修改OS核心数据结构(进程表、PCB池)
- 进程切换与模式切换
- 流程: 俩进程上下文切换(保存被中断的上下文、进程调度、恢复待运行的上下文)
- 模式切换:用户态到内核态这种。进程切换必须在内核态完成,所以必须经理模式切换
4. 线程
- 多线程技术:一个进程内有多个线程
- 思路:将进程的两个功能“独立分配资源”和“调度执行”功能分开
- 分类:
- KLT:内核级多线程
- ULT:用户级别多线程
- 多线程实现的混合策略
- 一个ULT绑定多个KLT

5. 处理器调度
- 处理器调度的层次:高级、中级、低级

- 处理器调度算法
- 原则:资源利用率、响应时间、周转时间(进入系统到出系统时间)、吞吐量(单位时间处理进程数)、公平性
- 算法:优先数算法、时间片轮转、分级调度算法、彩票算法
【重学计算机】操作系统D2章:处理器管理的更多相关文章
- 【重学计算机】操作系统D3章:存储管理
1. 存储管理的基本概念 逻辑地址:用户地址,从零开始编号 一维逻辑地址:(地址) 二维逻辑地址:(段号: 段内地址) 主存储器的复用方式 按分区:主存划分为多个固定/可变分区,一个程序占一个分区 按 ...
- 【重学计算机】操作系统D1章:计算机操作系统概述
1. 计算机软硬件系统 冯诺伊曼结构 以运算单元为核心,控制流由指令流产生 程序和数据存储在主存中 主存是按地址访问,线性编址 指令由操作码和地址码组成 数据以二进制编码 其他:参考<重学计算机 ...
- 【重学计算机】操作系统D6章:并发程序设计
1. 并发程序的基本概念 程序顺序性 内部顺序性:CPU严格按照顺序执行指令 外部顺序性:程序员设计程序时往往用顺序设计的思想 顺序程序特性 程序执行的顺序性 计算环境的封闭性: 程序执行时犹如独占资 ...
- 【重学计算机】操作系统D4章:设备管理
1. IO的控制方式 演进过程:轮询 --> 中断 --> DMA --> IO通道 经典布局:南北桥 PS:详见<计算机组成原理> 2. IO的实现 软件实现层次:硬件 ...
- 【重学计算机】计组D2章:数据表示
1.基本概念 真值:+0101,-0100:机器数: [x]原=0101 2.几种机器数 原码:x = -0101,[x]原 = 1101 反码:x = -0101,[x]反 = 1010 补码:x ...
- 【重学计算机】操作系统D5章:文件系统
1. 文件系统 文件系统概述 文件的组织: 逻辑结构:流式.记录式 物理结构:顺序.连接.直接.索引 文件的存取:顺序.直接.索引 文件的控制:逻辑控制.物理控制 文件的使用:打开.关闭.读.写.控制 ...
- 【重学计算机】机组D4章:存储系统
1. 存储系统层次结构 主存速度缓慢的原因:主存增速与CPU不同步,执行指令期间多次访问主存 主存容量不足的原因: 存在制约主存容量的技术因素:如由CPU.主板等相关技术指标规定了主存容量 应用对主存 ...
- 【重学计算机】计组D1章:计算机系统概论
1.冯诺依曼计算机组成 主机(cpu+内存),外设(输入设备+输出设备+外存),总线(地址总线+数据总线+控制总线) 2.计算机层次结构 应用程序-高级语言-汇编语言-操作系统-指令集架构层-微代码层 ...
- 【重学计算机】机组D8章:输入输出系统
1. 输入输出系统概述 组成:外设.接口.总线.管理软件 基本功能 完成计算机内外的信息传递 保证CPU正确选择输出设备 利用缓冲等,实现主机与外设的速度匹配 特点:异步性.实时性.设备无关性 输入过 ...
随机推荐
- spark SQL随笔
sparkSQL 1.主要的数据结构 DataFreames 2.开始使用:SQLContext 创建步骤: Val sc:sparkContext Val sqlContext=new org. ...
- CSS的浮动和定位
一.CSS中的浮动 1.定义和用法 float 属性定义元素在哪个方向浮动.在 CSS 中,任何元素都可以浮动.浮动会使原元素变成一个行级元素,而不论它本身是何种元素.如果浮动非替换元素,则要指定一个 ...
- MySQL类型float double decimal的区别
语法 MySQL 浮点型和定点型可以用类型名称后加(M,D)来表示,M表示该值的总共长度,D表示小数点后面的长度,M和D又称为精度和标度,如float(7,4)的 可显示为-999.9999,MySQ ...
- springboot数据库连接池使用策略
springboot官方文档介绍数据库连接池的使用策略如下: Production database connections can also be auto-configured using a p ...
- PAT1120: Friend Numbers
1120. Friend Numbers (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Two in ...
- 前端为什么非要动静分离 说一下CDN托管的意义
大型Web应用对速度的追求并没有止步于仅仅利用浏览器缓存,因为浏览器缓存始终只是为了提升二次访问的速度,对于首次访问的加速,我们需要从网络层面进行优化,最常见的手段就是CDN(Content Deli ...
- Servlet到底是单例还是多例你了解吗?
为一个Java Web开发者,你一定了解和学习过Servlet.或许还曾在面试中被问到过Servelt是单例还是多例这个问题. 遇到这个问题,你是否曾深入了解过,还是百度或者Google了一下,得到答 ...
- ETCD相关介绍--整体概念及原理方面
etcd作为一个受到ZooKeeper与doozer启发而催生的项目,除了拥有与之类似的功能外,更专注于以下四点. 简单:基于HTTP+JSON的API让你用curl就可以轻松使用. 安全:可选SSL ...
- java.sql.SQLException: Incorrect string value: '\xE5\xBC\xA0\xE9\x9B\xB7' for column 'content' at row 1
这个问题主要是由于该字段及腹肌编码不正确导致的,一般新建的表如果没设置就会是latin1字符集需要将表改为utf8字符集,再将报错的列的字符集改为utf8即可,修改命令如下所示: ALTER TABL ...
- 他学习一年Python找不到工作,大佬都说你别再学Python了!
引言: 都说,滴水穿石非一日之功.然而有些人即使奋斗一辈子也比不上别人一年,别人学习一年比不得你学习一个月.其中缘由,有些人看了大半辈子还没看明白. 即使Python这么火,为何你学习一年的Pytho ...