- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
文件系统实验报告
一、实验目的
了解操作系统中文件系统的原理以及实现方法。
二、实验方法
通过FAT12文件系统的解读,了解文件系统的原理和实现。
三、实验任务
通过对FAT12文件系统的了解,编写程序,读取并列出一个虚拟软盘中文件信
息(文件名、属性、修改时间等),以及读取其中的文件内容
四、实验要点
FAT12文件系统的了解,Linux系统下文件读写相关系统调用。
五、实验过程
1.FAT12文件系统分析
簇是操作系统分配文件空间的基本单位,簇由若干个扇区组成。在FAT12
文件系统中,簇号的有效位是12位,所以这种文件系统就被称为FAT12。FAT12
文件系统中大致可以分成五个区,这五个区为:
起始扇区占用扇区起始地址结束地址分区
0100x000001FF引导区
1900x000013FFFAT区
10900x000025FFFAT备份区
191200x00003DFF根目录区
31-0x00003E00-文件数据区
其中,引导区中储存着一些基本的信息。例如,0x0000000B和0x0000000C
两个字节保存着每个扇区的大小,0x0000000D保存着每个簇占用多少个扇区。
FAT区中储存着簇号。在0开始的三个字节,分别储存设备类
型标记(0xF0为软盘);第二个第三个字节均为0xFF,是FAT标识符。在FAT12
文件系统中,每个簇占用12位,即1.5个字节。簇号与地址的对应关系如下
表:
地址偏移000001002003004005
簇序号000001002003
一个簇号跨越两个字节,每次读取簇号时读取两个字节,然后对读出的两
个字节进行位运算处理,得到下一簇的簇序号。
注意,这里同样需要对高低位进行处理,即使用位计算的方式提取相应的
簇号信息。
根据上述的原理,可以得出一个函数,以一个簇号为参数,返回值为文件
下一个簇号。代码如下:
intgetNextClutserId(FILE*fp,shortclusterId)
{
unsignedshorttmp,low=0,high=0;;
intaddress=(clusterId*3/2)+0x0000200;
fseek(fp,address,SEEK_SET);
fread((void*)(tmp),1,sizeof(unsignedshort),fp);
low=((tmp0xFFF0)4);
high=tmp0x0FFF;
return(clusterId%2==0?high:low);
}
其中,fp是用于读取文件系统的文件流,clusterID是当前簇号,返回值
是下一个簇号。
函数体的第二句代码,计算出当前簇号对应的地址,用于文件指针的定位。
第三句代码是根据第二句计算得到的地址对文件指针进行定位,定位到当前簇
号所对应的信息处。第四句代码是从文件指针的位置为起始位置读入两个字节
的内容(fread会自动对高低字节位进
您可能关注的文档
最近下载
- 新人教版五年级数学上册《第二单元位置第1课时 确定位置(1)》课件.ppt VIP
- 城市轨道交通概论完整版全套PPT电子课件.ppt
- 《古诗中的家国情怀》群文阅读教学设计.docx VIP
- 2023年广东省新高考物理专题复习:磁场(含答案解析).pdf
- 2024年新《劳动法》与《劳动合同法》知识考试题库(附答案).pdf VIP
- 东营房地产市场月报2024年05月.ppt
- (新版)驾照科目一必备考试题库资料500题(含答案).pdf
- 徐冬 家务劳动--韭菜炒鸡蛋教学设计.docx VIP
- 2024年全国中小学“学宪法、讲宪法”知识竞赛题库及答案.docx VIP
- 金融行业的信息安全培训.pptx VIP
文档评论(0)