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)的更多相关文章

  1. FAT文件系统规范v1.03学习笔记---3.根目录区之FAT目录项结构

    1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...

  2. FAT文件系统规范v1.03学习笔记---4.文件和目录数据区之长目录项

    1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...

  3. FAT文件系统规范v1.03学习笔记---1.保留区之 Fat32 FSInfo扇区结构和备份启动扇区

    1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...

  4. FAT文件系统规范v1.03学习笔记---1.保留区之启动扇区与BPB

    1.前言 本文主要是对Microsoft Extensible Firmware Initiative FAT32 File System Specification中文翻译版的学习笔记. 每个FAT ...

  5. amazeui学习笔记二(进阶开发1)--项目结构structure

    amazeui学习笔记二(进阶开发1)--项目结构structure 一.总结 1.项目结构:是说的amazeui在github上面的项目结构,二次开发amazeui用 二.项目结构structure ...

  6. HDFS v1.0学习笔记

    hdfs是一个用于存储大文件的分布式文件系统,是apache下的一个开源项目,使用java实现.它的设计目标是可以运行在廉价的设备上,运行在大多数的系统平台上,高可用,高容错,易于扩展. 适合场景 存 ...

  7. mapreduce v1.0学习笔记

    它是什么? 一个用于处理大数据开源的分布式计算框架,它由java实现,原生提供java编程交互接口,其它语言通过hadoop streaming方式和mapreduce框架交互. 可以做什么? 利用框 ...

  8. pyecharts v1 版本 学习笔记 饼图,玫瑰图

    饼图: 普通案例 from example.commons import Faker from pyecharts import options as opts from pyecharts.char ...

  9. pyecharts v1 版本 学习笔记 折线图,面积图

    折线图 折线图 基本demo import pyecharts.options as opts from pyecharts.charts import Line c = ( Line() .add_ ...

随机推荐

  1. 被顶级学术期刊枪毙的p.Value到底是个什么鬼

    总结一下,在我看来,p.Value仅仅是在,假设检验,这理论框架下,对于证据力度的一个测量.而且,我们不大可能推翻假设检验这个框架,似乎也不必要,因为,这个框架非常合理,有广泛的应用场景,有强大的生命 ...

  2. flask 钩子函数

    说明: before_request函数,就是一个装饰器,他可以把需要设置为钩子函数的代码放到视图函数执行之前执行 示例: from flask import Flask,url_for,redire ...

  3. Hadoop端口说明

    Hadoop端口说明: 默认端口                            设置位置                                    描述信息 8020        ...

  4. python 进程锁 生产者消费者模型 队列 (进程其他方法,守护进程,数据共享,进程隔离验证)

    #######################总结######### 主要理解 锁      生产者消费者模型 解耦用的   队列 共享资源的时候 是不安全的 所以用到后面的锁 守护进程:p.daem ...

  5. python 函数动态参数,名称空间,global,nonlocal

    ##################################总结######################################动态参数 *args:位置参数动态传参,接收到的是元 ...

  6. Part-Eight 模板与群体数据的组织

    1.方法模板 #include<iostream> using namespace std; template<typename T> void outputArray(con ...

  7. node中glob模块

    glob glob允许使用规则,从而获取对应规则匹配的文件 node的glob模块允许你使用 * 等符号,来写一个glob规则,像在shell里一样,获取匹配对应规则文件 安装 npm install ...

  8. SpringBoot系列: 极简Demo程序和Tomcat war包部署

    =================================SpringBoot 标准项目创建步骤================================= 使用 Spring IDE( ...

  9. 【转】const int *p和int * const p的区别(常量指针与指向常量的指针)

    [转]作者:xwdreamer   出处:http://www.cnblogs.com/xwdreamer 对于指针和常量,有以下三种形式都是正确的: const char * myPtr = &am ...

  10. mysql插入记录INSERT与多表更新

    1.第一种:INSERT [INTO] tbl_name[ (col_name, ... ) ]  {VALUES | VALUE}({expr |default}, ... ), (...), .. ...