操作系统课程设计之三
设计任务:模拟OS文件系统在任一OS(Wi
dow或者Dos;也可以是在Li
ux下,但要求能将结果演示给老
师看)下,建立一个大文件,把它假象成一张盘,在其中实现一个简单的模拟OS文件系统。
1、在现有机器硬盘上开辟10M(共10000个盘块,每盘块大小为1k)的硬盘空间(生成一个10M的用户文件SDiskdat即可),作为设定的硬盘空间。
2、编写一管理程序SDisk,对此空间进行管理,以模拟OS文件系统,要求:⑴、盘块大小1k⑵、空闲盘块的管理:采用位示图法⑶、文件空间管理:采用FAT(文件分配表),每个盘块号占2个字节⑷、目录项管理:①、每个目录项占用32字节,其中前8个字节(07)为文件名,之后跟3个字节
(810)的扩展名,2627字节,存放文件的第一个盘块号,最后四个字节(2831),存放文件长度(如果目录项对应的是下一级子目录(文件),其文件长度部分为0)②、目录按文件方式管理,每个目录仅用一个盘块(即1k,最多装32个目录项)③、第0个目录项为本目录,即“”,第0个字节为“”,即0x2E,第2627字节指明本目录所在盘块。④、第1个目录项为父目录,即“”,第0,1个字节为“”即0x2E0x2E,第2627字节指明父目录所在盘块。⑤、每个目录实际能放下文件或子目录30项。⑸、文件系统空间分配:①、第0个盘块(1k)存放磁盘信息(可以设定为格式说明“FAT32”、盘块大小,盘块数等内容)②、第1个盘块起,至125盘块,共125个盘块(125k)存放FAT内容③、第126、127(2个)盘块,存放位示图④、从第128盘块至10000盘块,皆为数据(区)盘块,其逻辑编号从0开始,至
f9872号数据盘块,即第0数据盘块为128号盘块,第1数据盘块为129号盘块,…⑤、第0数据盘块(即128号盘块),存放根目录(同样只用一个盘块作根目录),
由于第0、1目录项为“”(本目录)“”(父目录),因此根目录下同样只能存放30个文件或目录,并且从第2个目录项开始。⑥、文件或子目录数据,放在第1数据盘块及以后的数据盘块中,由用户按需要使用。
3、SDisk管理程序的功能要求如下:⑴、正常情况下,显示等待命令输入符号⑵、改变目录命令:
cd目录名,改变当前工作目录,目录不存在时给出出错信息cd,返回上一级目录,如果是根目录,给出提示信息⑶、生成新目录md目录名,创建新目录(需要更改FAT内容和位示图内容)⑷、删除目录rd目录名,删除目录,如果目录不存在时给出出错信息(需要更改FAT内容和位示图内容)r