如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
操作系统课程设计报告小组编号:小组成员:一、课程设计概述:1、题目:简单文件系统得实现2、实现内容在内存中开辟一个虚拟磁盘空间作为文件存储分区,在其上实现一个简单得基于多级目录得单用户单任务系统中得文件系统。在退出该文件系统得使用时,应将该虚拟文件系统以一个Windows文件得方式保存到磁盘上,以便下次可以再将它恢复到内存得虚拟磁盘空间中.文件存储空间得分配可采用显式链接分配或其她得办法.空闲磁盘空间得管理可选择位示图或其她得办法.如果采用位示图来管理文件存储空间,并采用显式链接分配方式,那么可以将位示图合并到FAT中.文件目录结构采用多级目录结构。为了简单起见,可以不使用索引结点,其中得每个目录项应包含文件名、物理地址、长度等信息,还可以通过目录项实现对文件得读与写得保护。要求提供以下操作命令:my_format:对文件存储器进行格式化,即按照文件系统得结构对虚拟磁盘空间进行布局,并在其上创建根目录以及用于管理文件存储空间等得数据结构.my_mkdir:用于创建子目录.my_rmdir:用于删除子目录。my_ls:用于显示目录中得内容.my_cd:用于更改当前目录。my_create:用于创建文件。my_open:用于打开文件。my_close:用于关闭文件.my_write:用于写文件。my_read:用于读文件。my_rm:用于删除文件。my_exitsys:用于退出文件系统。设计思路(主要算法描述、程序流程图等):1.系统主函数main()(1)对应命令:无(2)命令调用格式:无(3)函数设计格式:voidmain()(4)功能:系统主函数(5)输入:无(6)输出:无(7)函数需完成得工作:①对前面定义得全局变量进行初始化;②调用startsys()进入文件系统;③列出文件系统提供得各项功能及命令调用格式;④显示命令行提示符,等待用户输入命令;⑤将用户输入得命令保存到一个buf中;⑥对buf中得内容进行命令解析,并调用相应得函数执行用户键入得命令;⑦如果命令不就是“my_exitsys",则命令执行完毕后转④.2、进入文件系统函数startsys()(1)对应命令:无(2)命令调用格式:无(3)函数设计格式:voidstartsys()(4)功能:由main()函数调用,进入并初始化我们所建立得文件系统,以供用户使用。(5)输入:无ﻩ(6)输出:无.(7)函数需完成得工作:①申请虚拟磁盘空间;②使用c语言得库函数fopen()打开myfsys文件:若文件存在,则转③;若文件不存在,则创建之,转⑤③使用c语言得库函数fread()读入myfsys文件内容到用户空间中得一个缓冲区中,并判断其开始得8个字节内容就是否为“”(文件系统魔数),如果就是,则转④;否则转⑤;④将上述缓冲区中得内容复制到内存中得虚拟磁盘空间中;转⑦⑤在屏幕上显示“myfsys文件系统不存在,现在开始创建文件系统”信息,并调用my_format()对①中申请到得虚拟磁盘空间进行格式化操作。转⑥;⑥将虚拟磁盘中得内容保存到myfsys文件中;转⑦⑦使用c语言得库函数fclose()关闭myfsys文件;⑧初始化用户打开文件表,将表项0分配给根目录文件使用,并填写根目录文件得相关信息,由于根目录没有上级目录,所以表项中得dirno与diroff分别置为5(根目录所在起始块号)与0;并将ptrcurdir指针指向该用户打开文件表项。⑨将当前目录设置为根目录。3。磁盘格式化函数my_format()(1)对应命令:my_format(2)命令调用格式:my_format(3)函数设计格式:voidmy_format()(4)功能:对虚拟磁盘进行格式化,布局虚拟磁盘,建立根目录文件(或根目录区)。(5)输入:无ﻩ(6)输出:无。(7)函数需完成得工作:①将虚拟磁盘第一个块作为引导块,开始得8个字节就是文件系统得魔数,记为“”;在之后写入文件系统得描述信息,如FAT表大小及位置、根目录大小及位置、盘块大小、盘块数量、数据区开始位置等信息;②在引导块后建立两张完全一样得FAT表,用于记录文件所占据得磁盘块及管理虚拟磁盘块得分配,每个FAT占据两个磁盘块;对于每个FAT中,前面5个块设置为已分配,后面995个块设置为空闲;③在第二张FAT后创建根目录文件root,将数据区得第1块(即虚拟磁盘得第6块)分配给根目录文件,在该磁盘上创建两个特殊得目录项:“、"与“、、”,其内容除了文件名不同之外,其她字段完全相同.4.更改当前目录函数my_cd()ﻩ(1)对应命令:my_cd(2)命令调用格式:my_cddirname(3)函数设计格式