第五章 I/O管理 十二、磁盘的管理

目录

一、磁盘初始化

[Step 1:](#Step 1:)

[Step 2:](#Step 2:)

[Step 3:](#Step 3:)

二、引导块

三、坏块的管理

1、坏块的定义:

2、管理:

(1)对于简单的磁盘:

(2)对于复杂的磁盘;

四、总结


一、磁盘初始化

步骤:

Step 1:

  • 进行低级格式化(物理格式化),将磁盘的各个磁道划分为扇区。
  • 一个扇区通常可分为头、数据区域(如512B大小)、尾三个部分组成。
  • 管理扇区所需要的各种数据结构一般存放在头、尾两个部分,包括扇区校验码
  • (如奇偶校验、CRC循环冗余校验码等,校验码用于校验扇区中的数据是否发生错误)

Step 2:

  • 将磁盘分区,每个分区由若干柱面组成(即分为我们熟悉的C盘、D盘、E盘)

Step 3:

  • 进行逻辑格式化,创建文件系统。
  • 包括创建文件系统的根目录、初始化存储空间管理所用的数据结构(如位示图、空闲分区表)

二、引导块

三、坏块的管理

1、坏块的定义:

  • 坏了、无法正常使用的扇区就是"坏块"。这属于硬件故障,操作系统是无法修复的。
  • 应该将坏块标记出来,以免错误地使用到它

2、管理:

(1)对于简单的磁盘:

可以在逻辑格式化时(建立文件系统时)对整个磁盘进行坏块检查,标明哪些扇区是坏扇区,比如:在FAT表上标明。(在这种方式中,坏块对操作系统不透明)

(2)对于复杂的磁盘;

磁盘控制器(磁盘设备内部的一个硬件部件)会维护一个坏块链表。

在磁盘出厂前进行低级格式化(物理格式化)时就将坏块链进行初始化。

会保留一些"备用扇区",用于替换坏块。这种方案称为扇区备用。且这种处理方式中,坏块对操作系统透明。

四、总结

相关推荐
Mr Xu_7 小时前
告别硬编码:前端项目中配置驱动的实战优化指南
前端·javascript·数据结构
czxyvX7 小时前
017-AVL树(C++实现)
开发语言·数据结构·c++
数智工坊7 小时前
【数据结构-队列】3.2 队列的顺序-链式实现-双端队列
数据结构
elseif1238 小时前
【C++】并查集&家谱树
开发语言·数据结构·c++·算法·图论
徐小夕@趣谈前端8 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
Nebula_g9 小时前
线程进阶: 无人机自动防空平台开发教程(更新)
java·开发语言·数据结构·学习·算法·无人机
xuxie9910 小时前
day 23 树
数据结构
EnglishJun11 小时前
数据结构的学习(四)---栈和队列
数据结构·学习
数智工坊11 小时前
【数据结构-特殊矩阵】3.5 特殊矩阵-压缩存储
数据结构·线性代数·矩阵
芝士爱知识a11 小时前
AlphaGBM 深度解析:下一代基于 AI 与蒙特卡洛的智能期权分析平台
数据结构·人工智能·python·股票·alphagbm·ai 驱动的智能期权分析·期权