操作系统原理之I/O设备管理(第六章上半部分下)
五、I/O软件原理
输入输出软件的总体目标是将软件组织成一种层次结构
- 低层软件用来屏蔽硬件的具体细节
- 高层软件则主要是为用户提供一个简洁、规范的界面
设备管理的4个层次:
- 用户层软件 -》向系统发出I/O请求,显示I/O操作的结果,提供⽤户与设备的接⼝
- 与设备无关的软件层-》完成设备命名、设备分配、设备独⽴性和缓冲管理等功能
- 设备驱动程序-》与硬件关系最密切,包括设备服务程序和中断处理程序
- 中断处理程序(底层)-》
设备管理软件的功能:
(1)实现I/O设备的独⽴性
(2)错误处理
(3)异步传输
(4)缓冲管理
(5)设备的分配和释放
(6)实现I/O控制⽅式
中断处理程序
中断处理程序的作⽤:I/O中断处理程序的作⽤是将发出I/O请求⽽被阻塞的进程唤醒
设备驱动程序:
与硬件⽆关的I/O软件:
与设备⽆关的I/O软件的功能如下:
(1)设备命名
(2)设备保护
(3)提供独⽴于设备的块⼤⼩
(4)为块设备和字符设备提供必要的缓冲技术
(5)块设备的存储分配
(6)分配和释放独⽴设备
(7)错误处理
六、 磁盘管理
- 磁盘存储器容量⼤,存取速度快,⽽且可以实现随机存取,是存放⼤量程序和数据的理想设备;
- 磁盘管理的重要⽬标是提⾼磁盘空间利⽤率和磁盘访问速度
磁盘结构:
⼀个物理记录存储在⼀个扇区上,磁盘存储的物理记录数⽬是由扇区数、磁道数及
磁盘⾯数决定的。
磁盘类型:
- 固定头磁盘 在每条磁道上都有读/写磁头
- 活动头磁盘 (移动头):每⼀个盘⾯仅配有⼀个磁头
磁盘访问时间:
磁盘调度
磁盘调度的一个重要目标是使磁盘的平均寻道时间最少
磁盘调度算法
- 先来先服务 (First Come First Served, FCFS)
- 最简单的磁盘调度算法 根据进程请求访问磁盘的先后顺序进⾏调度
- 优点:公平、简单,且每个进程的请求都能依次得到处理,不会出现某⼀ 进程的请求⻓期得不到满⾜的情况
- 缺点:平均寻道时间较⻓
- 最短寻道时间优先 (Shortest Seek Time First, SSTF)
- 该算法选择的进程:其要求访问的磁道与当前磁头所在的磁道距离最近, 以使每次的寻道时间最短。
- 优点:每次的寻道时间最短,较之FCFS有更好的寻道性能
- 缺点:可能导致某个进程发⽣“饥饿”现象
- 扫描算法 (SCAN)
不仅考虑到要访问的磁道与当前磁道的距离,更优先考虑磁头当前的移动⽅向。
优点:有较好的寻道性能,防⽌“饥饿”现象
缺点:有时候进程请求被⼤⼤推迟
- 循环扫描算法 (CSCAN)
在扫描算法的基础上,规定磁头是单向移动的。将最⼩磁道号紧接着最⼤磁道号构成循环,进⾏循环扫描。
- NStepSCAN和FSCAN调度算法
这两种算法可以避免磁臂粘着
计算题
假设磁盘有1000个磁道,若磁盘请求是一些随机请求,它们按照到达的次序分别处于 811、 348、153、968、407、580、233、679、801、121磁道。当前磁头在656号 磁道上,并且读写磁头正在向磁道号增加的方向移动。
要求: 1.给出用FCFS算法进行磁盘调度时满足请求的次序,并计算出它们的平均寻道长度。
2.给出用SSTF算法进行磁盘调度时满足请求的次序,并计算出它们的平均寻道长度。
假设磁盘有1000个磁道,若磁盘请求是一些随机请求,它们按照到达的次序分别处于150、 160、 184、90、58、55、39、38、18磁道。当前磁头100号磁道上,并且读写磁头正在向磁道号增 加的方向移动。
要求: 1.给出用SCAN算法进行磁盘调度时满足请求的次序,并计算出它们的平均寻道长度。
2.给出用CSCAN算法进行磁盘调度时满足请求的次序,并计算出它们的平均寻道长度。
提⾼磁盘I/O速度的⽅法
为了提高磁盘I/O速度,用来暂存从磁盘中读出的一系列盘块中的信息的方 法是磁盘高速缓存
操作系统原理之I/O设备管理(第六章上半部分下)的更多相关文章
- “全栈2019”Java第十六章:下划线在数字中的意义
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- 操作系统原理之I/O设备管理(第六章上半部分)
一.I/O系统的组成 I/O系统不仅包括各种I/O设备,还包括与设备相连的设备控制器,有些系统还配备了专⻔⽤ 于输⼊/输出控制的专⽤计算机,即通道.此外,I/O系统要通过总线与CPU.内存相连. I/ ...
- Intel汇编语言程序设计学习-第六章 条件处理-下
6.6 应用:有限状态机 这个东西说了半天,感觉就是把逻辑弄得跟有向图一样,没看出来什么高端的东西,下面就整理下书上说的概念: 有限状态机(FSM,Finite-State Machine)是依据输 ...
- 操作系统原理2——OS结构
操作系统原理2——OS结构 计算机系统是由硬件系统和软件系统两部分组成, 操作系统是软件系统的一个组成部分,它是直接在硬件系统的基础上工作的,所以在研究操作系统之前,先必须对计算机系统的结构有一个 ...
- 网络操作系统 第六章 Window Server 2008 活动目录
本章小结 在企业网络中,活动目录是必不可少的,它将网络中各种对象组织起来进行管理,方便了网络对象的查找,增强了网络的安全性,为用户的物流管理提供了极大的便利,本章首先介绍了活动目录的基本概念,然后通过 ...
- Linux操作系统原理
Linux操作系统原理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.计算机经历的四个时代 1.第一代: 真空管计算机,输入和输出:穿孔卡片,对计算机操作起来非常不便,做一件事 ...
- [CSAPP笔记][第六章存储器层次结构]
第六章 存储器层次结构 在简单模型中,存储器系统是一个线性的字节数组,CPU能够在一个常数访问每个存储器位置. 虽然是一个行之有效的模型,但没有反应现代系统实际工作方式. 实际上,存储器系统(memo ...
- 第六章P2P技术及应用
第六章P2P技术及应用 P2P技术在我们日常生活中非常实用,例如我们常用的QQ.PPLive.BitTorrent就是基于P2P技术研发.下面将本章中的重点内容进行归纳. 文章中的Why表示产生的背景 ...
- 精通Web Analytics 2.0 (8) 第六章:使用定性数据解答”为什么“的谜团
精通Web Analytics 2.0 : 用户中心科学与在线统计艺术 第六章:使用定性数据解答"为什么"的谜团 当我走进一家超市,我不希望员工会认出我或重新为我布置商店. 然而, ...
随机推荐
- Spring项目集成ShiroFilter简单实现权限管理
Shiros是我们开发中常用的用来实现权限控制的一种工具包,它主要有认证.授权.加密.会话管理.与Web集成.缓存等功能.我是从事javaweb工作的,我就经常遇到需要实现权限控制的项目,之前我们都是 ...
- AutoCAD.NET中添加图形对象的基本步骤与实例演示
https://blog.csdn.net/u011170962/article/details/37755201 要创建一个图形对象,需要遵循下面的步骤:1.得到创建对象的图形数据库:2.在内存中创 ...
- unsqueeze 和 squeeze
squeeze压缩的意思 就是在第几维为1 去掉 unsqueeze 解缩 在第几维增加 变成*1 squeeze用法 c = b.view(1, 1, 1, 2, 3) c.squeeze(0) # ...
- 前端小知识-css3
一.实现图片倒影 如图: css属性 .style{ -webkit-box-reflect:below 0 linear-gradient(transparent,white 50% ,white) ...
- ggplot2 |legend参数设置,图形精雕细琢
本文首发于微信公众号“生信补给站”,https://mp.weixin.qq.com/s/A5nqo6qnlt_5kF3_GIrjIA 学习了ggplot2|详解八大基本绘图要素后,就可以根据自己的需 ...
- .NET中的缓存
构建高性能的应用程序的非常重要一项就是使用缓存.使用缓存可以避免重新从读取服务器端读取数据,节省数据从客户端到服务器间往返的时间,同时也减轻了服务器数据存取的压力.如果客户端非常频繁地读取服务器上的数 ...
- DIY显示器篇------DIY教程
前言: DIY显示器是这几年才火起来的,或者说这几年在游戏圈火起来的.我第一次看到是在NGA上,一位玩PUBG的大佬自己DIY了一个显示器,27寸 2k 144 ips的屏幕,当时市面上只有四款显示器 ...
- c++json构建与解析组件 RapidJSON 没用过永远不会知道有多好用
参考资料: 官方文档 推荐[腾讯RapidJSON]学习笔记 原理请参考以上资料 构建json Document doc; Document::AllocatorType &allocator ...
- python多进程通信实例分析
操作系统会为每一个创建的进程分配一个独立的地址空间,不同进程的地址空间是完全隔离的,因此如果不加其他的措施,他们完全感觉不到彼此的存在.那么进程之间怎么进行通信?他们之间的关联是怎样的?实现原理是什么 ...
- javaScript 基础知识汇总(六)
1.基本类型与对象的区别 基本类型:是原始类型的中的一种值. 在JavaScript中有6中基本类型:string number boolean symbol null undefined 对 ...