FAT文件系统规范v1.03学习笔记---2.FAT区之FAT数据结构(Fat Data Structure)
1.前言
本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记。
每个FAT文件系统基本区域由4部分组成,这些基本区域按如下顺序排列:


FAT32典型布局如下:

上一部分主要介绍了Rerverd Region中的启动扇区与BPB,本节继续介绍Fat Region
Fat Region包含Fat表,它位于Rerserved Region之后
2.FAT区(Fat Data Structure)
2.1 FAT表
注:[1]FAT区存放FAT表(Fat Allocate Table),FAT表由FAT表项构成。FAT表是FAT表项与文件和目录数据区簇号一一对应的列表
[2]文件系统分配磁盘空间是按簇分配,簇是操作系统分配的最小单位
数据区被分成BPB_BytePerSec * BPB_SecPerC字节大小的很多簇进行管理
[3]一个FAT表项用来管理一个簇,FAT表项大小与文件系统类型有关
FAT12为12bit,FAT16为16bit,FAT32位32bit,每个FAT表项都有一个固定的编号,这个编号从0开始
[4]对于大文件有多个簇,同一个文件可能并不会存储在磁盘上的连续区域,而是分成若干段,称为文件的链式存储
FAT表项会记录簇是否被文件占用、指明占用簇的后继簇号、指明是否是尾簇
[5]FAT表的0号和1号FAT表项有专门的用途
0号FAT表项通常用来存放分区所在的介质类型;1号FAT表项用来存储文件系统的肮脏标志,表明文件系统被非法卸载或者磁盘表面存在错误
[6]从2号FAT表项开始跟数据区中的第一个簇映射
因为0号FAT表项和1号FAT表项有特殊用途,无法与数据区中的簇形成映射,所以 数据区中的第一个簇也就编号为2号簇,这也是没有0号簇和1号簇的原因。
然后3号簇跟3号FAT表项映射,4号簇跟4号FAT表项映射,以此类推,直到数据区中的最后一个簇
---根目录区所占的扇区数计算公式:

对于FAT12和FAT16 RootDirSectors=((512*32)+(BPB_BytesPerSec-1))/BPB_BytsPerSec
对于FAT32 RootDirSectors=((0*32)+(BPB_BytesPerSec-1))/BPB_BytsPerSec=0
--- 簇2的第一个扇区计算公式:

FATSz为FAT表所占用的扇区数,BPB_RsvdSecCnt为保留区中扇区数目
下表FAT表中每个FAT项可取的表项值及其含义:

如下以FAT16说明FAT区的结构:

2.2 FAT类型辨别
TODO
FAT文件系统规范v1.03学习笔记---2.FAT区之FAT数据结构(Fat Data Structure)的更多相关文章
- FAT文件系统规范v1.03学习笔记---3.根目录区之FAT目录项结构
1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...
- FAT文件系统规范v1.03学习笔记---4.文件和目录数据区之长目录项
1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...
- FAT文件系统规范v1.03学习笔记---1.保留区之 Fat32 FSInfo扇区结构和备份启动扇区
1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...
- FAT文件系统规范v1.03学习笔记---1.保留区之启动扇区与BPB
1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...
- amazeui学习笔记二(进阶开发1)--项目结构structure
amazeui学习笔记二(进阶开发1)--项目结构structure 一.总结 1.项目结构:是说的amazeui在github上面的项目结构,二次开发amazeui用 二.项目结构structure ...
- HDFS v1.0学习笔记
hdfs是一个用于存储大文件的分布式文件系统,是apache下的一个开源项目,使用java实现.它的设计目标是可以运行在廉价的设备上,运行在大多数的系统平台上,高可用,高容错,易于扩展. 适合场景 存 ...
- mapreduce v1.0学习笔记
它是什么? 一个用于处理大数据开源的分布式计算框架,它由java实现,原生提供java编程交互接口,其它语言通过hadoop streaming方式和mapreduce框架交互. 可以做什么? 利用框 ...
- pyecharts v1 版本 学习笔记 饼图,玫瑰图
饼图: 普通案例 from example.commons import Faker from pyecharts import options as opts from pyecharts.char ...
- pyecharts v1 版本 学习笔记 折线图,面积图
折线图 折线图 基本demo import pyecharts.options as opts from pyecharts.charts import Line c = ( Line() .add_ ...
随机推荐
- numpy知识点
1.nonzero 对于一维数据来说,将返回符合条件的 下标 >>> b1 = np.array([True, False, True, False]) >>> n ...
- puppeteer端对端测试demo
1. 下载pupperteer npm i puppeteer 2. 启动一个本地服务 localhost 3. 开启测试 const puppeteer = require('puppeteer') ...
- JavaSE_坚持读源码_HashSet对象_Java1.7
对于 HashSet 而言,它是基于 HashMap 实现的,HashSet 底层采用 HashMap 来保存所有元素,因此 HashSet 的实现比较简单,查看 HashSet 的源代码,可以看到如 ...
- 设计模式---状态变化模式之备忘录模式(Memento)
一:概念 用于保存对象的内部状态,并在需要的时候(undo/rollback)回复对象以前的状态 二:应用场景 如果一个对象需要保存状态并可通过undo或rollback等操作恢复到以前的状态时,可以 ...
- Redis_集群_主从模式_哨兵模式
1.主从模式 2.哨兵模式
- PHP7 网络编程(三)孤儿进程与僵尸进程
基本概念 我们知道在unix/linux中,正常情况下,子进程是通过父进程创建的,子进程在创建新的进程.子进程的结束和父进程的运行是一个异步过程,即父进程永远无法预测子进程 到底什么时候结束. 当一个 ...
- Spark整合HBase,Hive
背景: 场景需求1:使用spark直接读取HBASE表 场景需求2:使用spark直接读取HIVE表 场景需求3:使用spark读取HBASE在Hive的外表 摘要: 1.背景 2.提交脚本 内容 场 ...
- 几本不错的数据仓库和Hadoop书籍
<<Pentaho Kettle解决方案:使用PDI构建开源ETL解决方案>>, Matt Casters等著,初建军翻译<<Hadoop应用架构>> ...
- 《Python数据可视化编程实战》
第一章:准备工作环境 WinPython-32bit-3.5.2.2Qt5.exe 1.1 设置matplotlib参数 配置模板以方便各项目共享 D:\Bin\WinPython-32bit-3.5 ...
- ubuntu安装matlab
https://blog.csdn.net/qq_36982160/article/details/78397514 https://blog.csdn.net/weixin_40294256/art ...