简单文件系统的实现的实验报告_操作系统课程设计.doc

简单文件系统的实现的实验报告_操作系统课程设计.doc

  1. 1、本文档共37页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
简单文件系统的实现的实验报告_操作系统课程设计

杭州电子科技大学 操作系统课程设计 课程设计题目:简单文件系统的实现 学院:计算机学院 专业:计算机科学与技术(2+2) 完成日期:2012-5-28 简单文件系统的实现 课程设计的目的 通过具体的文件爱你存储空间的管理、文件的物理结构、目录结构和文件操作的实现,加深对文件系统内部数据结、功能及实现过程的理解 设计要求 在内存中开辟一个虚拟磁盘空间作为文件存储分区,在其上实现一个简单的基于多级目录的但用户单任务系统的文件系统。在退出文件系统的使用时,应将虚拟文件系统一个Windows文件的方式保存到磁盘中,以便下次再将它恢复到内存的虚拟磁盘空间中 文件存储空间的分配可采用显示链接分配或其它方法 空闲磁盘空间的管理可选择位示图或其它方法 文件目录结构采用多级目录结构 需要提供一以下操作命令 Format Mkdir Rmdir Ls Cd Create Open Close Write Read Rm Exit 程序设计思想以及总流程图 程序设计思想 首先,在文件系统启动时,申请一块较大的内存,用来当作文件系统的磁盘空间 然后,对其进行格式化,虚拟磁盘的空间布局是仿照FAT16文件系统,结构如下: 1块 2块 2块 995块 引导块 FAT1 FAT2 数据区 格式化时,主要包括引导块,FAT1,FAT2,的一些初始化工作 例如设置文件魔数,文件系统的信息,FAT1,FAT2的信息等等 根据用户输入的命令,调用对应的函数. 程序流程图 文件系统存在 文件系统不存在 等待用户输入命令 。。。 系统各个功能的实现思想 创建目录 调用do_read读入当前目录文件到内存,检查新建文件目录是否重名 分配一个空闲的打开文件表项 分配一个空闲的盘块 在当前目录中问新建目录寻找一个空闲的目录项 设置FCB,文件的属性信息 创建特殊的两个目录项‘.’,‘..’ 返回 Cd命令 Open指定的目录名,调用read读入该父目录到内存 检查新的当前目录名是否存在 关闭原当前目录 设置当前目录为该目录 Rmdir命令 Read读入当前目录文件内容到内存,检查要删除的文件目录是否存在 检查该目录是否为空 检查是否已经打开,打开用close则关闭 回收给目录文件的磁盘块 修改该目录文件的目录项 修改用户打开表项的长度信息 返回 Ls命令 Read当前目录到内存 读出目录文件的信息,显示到屏幕上 返回 Create命令 分配一个空闲的打开文件表项 检查新文件的父目录是否打开 Read该父目录的文件到内存,并检测新建的文件名是否重名 检查是否有空闲盘块 寻找空闲的目录项 准备好新文件的FCB 调用close关闭打开的父目录文件 返回 Rm命令 检查要删除的文件的父目录是否已打开 Read父目录到内存 检查文件是否打开 回收磁盘快 清空该文件的目录项 修改用户打开文件表项中的长度信息 返回 Open命令 检查该文件名是否存在 Read该父目录到内存 检查用户打开的文件表中是否有空闲表项 为该文件填写空白用户打开文件表项内容 返回 Close 检查fd的有效性 检查用户打开文件表表项的fcbstate字段 回收该文件占据的用户打开文件表表项 返回 Write命令 检查fd的有效性 提示用户输入写方式 提示用户输入内容 调用do_write()将键入的内容写入到文件中 返回写入的字节数 系统的详细过程 #includestdio.h #includemalloc.h #includetime.h #includestdlib.h #includestring.h #define BLOCKSIZE 1024 #define SIZE 1024000 #define END 65535 #define FREE 0 #define ROOT_BLOCKNUM 2 #define MAX_OPEN_FILE 10 #define MAX_TXT_SIZE 10000 typedef struct FCB { char filename[8]; /*8B文件名*/ char exname[3]; /*3B扩展名*/ unsigned char attribute; /*文件属性字段*/ char retainbyte[10] ; /*10B保留字*/ unsigned short time; /*文件创建时间*/ unsigned short date; /*文件创建日期*/ unsigned short first; /*首块号*/ u

文档评论(0)

pangzilva + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档