标签:组成 校验码 优先 柱面 维护 记录 活动 str 创建文件系统
磁盘的表面由一些磁性物质组成, 可以用这些磁性物质来记录二进制数据
磁道 : 磁盘的盘面被划分成一个个磁道, 一个圈就是一个磁道
扇区 : 每一个磁道被划分成一个个扇区, 每个扇区就是一个个 " 数据块 ", 各个扇区存放的数据量相同
( 最内侧磁道上的扇区面积最小, 因此数据密度最大 )
如何根据地址读取一个块 :
根据磁头是否可以移动 :
活动头磁盘
固定头磁盘
根据盘片是否可以更换 :
在读 / 写数据之前, 把磁头移动到指定磁道所花的时间
通过旋转磁盘, 使磁头定位到目标扇区所需要的时间
由磁盘读出 或 向磁盘写入数据所需要的时间
磁盘调度算法会直接影响寻道时间
根据进程请求访问磁盘的先后顺序进行调度
SSTF算法会优先处理的磁道是离当前磁头最近的磁道, 可以保证每一次的寻道时间最短, 但是并不能保证总体寻道时间最短 ( 贪心 )
SSTF算法产生饥饿的原因 : 磁头可能会在一个小区域内来回移动
SCAN :
只有磁头移动到最外侧磁道的时候才能往内移动, 移动到最内侧磁道的时候才能往外移动
在扫描算法的基础上增加 :
如果在磁头移动方向上已经没有别的请求, 就可以立即改变磁头移动方向
SCAN算法对于各个位置磁道的响应频率不平均, C-SCAN算法就是为了解决这个问题, 规定只有磁头朝特定方向移动时才处理磁道访问请求, 而返回时 直接快速移动至起始端而不处理任何情况
C-LOOK = C-SCAN + LOOK
延迟时间 : 把目标扇区转动到磁头下所花的时间
由于磁头读入一个扇区数据后需要一小段时间处理, 如果逻辑上相邻的扇区在物理上也相邻, 则读入几个连续的逻辑扇区, 可能需要很长的 " 延迟时间 ".
采用交替编号的策略, 让逻辑上相邻的扇区在物理上有一定的间隔, 可以使读取连续的逻辑扇区所需要的延迟时间更小
将盘面之间的扇区不同样按顺序编号
而是使用0号盘面的1号扇区下是1号盘面的4号扇区....这样的方式
这样使得读取完磁盘块之后还有一段时间处理, 从而减少了延迟时间
采用 ( 柱面号, 盘面号, 扇区号 )--- 三维, 二维, 一维
计算机开机时需要进行一系列初始化的工作, 这些初始化工作是通过执行初始化程序 (自举程序) 完成的.
初始化程序 ( 自举程序 ) 如果直接放在ROM中, 会很不方便, 因为ROM中的数据无法更改, 解决方法 :
ROM中只存放很小的 " 自举装入程序 "
开机时计算机先运行 " 自举装入程序 ", 通过执行该程序就可以找到引导块, 并将完整的" 自举程序 " 读入内存, 完成初始化
对于简单的磁盘
,可以在逻辑格式化时, 对磁盘进行坏块检查, 表明哪些扇区是坏扇区. 这种处理方式中, 坏块对操作系统不透明
对于复杂的磁盘
, 磁盘控制器 ( 磁盘设备内部的一个硬件部件 ) 会维护一个坏块链表. 在磁盘出厂前进行低级格式化时就将坏块链进行初始化. 会保留一些 " 备用扇区 " 用于替换坏块. 这种方案称为扇区备用 . 这种处理方式中, 坏块对操作系统透明.
标签:组成 校验码 优先 柱面 维护 记录 活动 str 创建文件系统
原文地址:https://www.cnblogs.com/roccoshi/p/13165860.html