一个简单的文件系统的详细设计操作系统课程设计.pdf





《一个简单的文件系统的详细设计操作系统课程设计.pdf》由会员分享,可在线阅读,更多相关《一个简单的文件系统的详细设计操作系统课程设计.pdf(43页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 word 文档 可自由复制编辑 计算机系综合性实验 实 验 报 告 课程名称 操作系统实验报告 实验学期 2013 至 2014 学年 第 一 学期 学生所在系部 计算机与信息管理系 年级 2011 专业班级 计算机 102 学生姓名 王强 黄新潮 张蒙 学号 11030082 11030070 11030077 任课教师 陆丽娜 实验成绩 计算机系制 word 文档 可自由复制编辑 一个简单的文件系统的详细设计 一、实验目的(1)阅读并调试一个简单的文件系统,模拟文件管理的工作过程。从而对各种文件操作命令的实质内容和执行过程有比较深入的了解。(2)了解设计一个 n 个用户的文件系统,每个用
2、户可以保存 M 个文件。用户在一次运行中只能打开一个文件,对文件必须设置保护措施,且至少有 create、delete、open、close、read、write 等命令。二、实验要求 1、根据流程图阅读所给文件系统源程序,并对源程序加以注释(注释量达 70%以上)。2、修改、完善该系统,指出程序的 bug。三、文件系统功能设计 1.功能设计 该文件系统是一个多用户、多任务的文件系统。对用户和用户的文件数目并没有上限。也就是说该系统允许任何用户申请空间,而且在其目录下的文件数目并不做任何的限制。该系统可以支持的操作命令如下:bye用户注销命令。当使用该命令时,用户退出系统,注销该用户功能设计并
3、回到登陆界面。命令格式:bye close删除用户注册信息命令。执行该命令后,用户在系统中的所有信息,包括该用户目录下的所有文件都被删除。命令执行完成后返回登陆界面。命令格式:close create在当前目录下创建一个文件,且该文件不能跟当前已有的文件重名。该文件的管理信息登记在用户文件信息管理模块中。执行完该命令后回到执行命令行。命令格式:createfile1 其中:“”符为提示符,file1 为要创建的文件名。delete删除当前用户目录下的一个文件,命令执行完毕返回至命令行。命令格式:deletefile1 其中:file1 为要删除的文件名。list显示当前注册目录下的所有文件信息
4、,包括文件名、文件长度、文件操作权限。命令格式:list chmod改变某个文件的执行权限,但前提是该文件是该用户目录下的文件。命令格式:chmodfile1。其中:file1 为要授权的文件名。open在 window 界面下打开某个文件。执行该命令后,文件 file1 将用在 windows界面下的文件形式打开。用户可以在这个方式中对文件进行修改,并将修改后的内容保存。word 文档 可自由复制编辑 命令格式:openfile1 其中:file1 为要打开的文件名。read读文件信息。将文件信息读入并显示在终端上。命令格式:readfile1 其中:file1 为要读的文件名。write向
5、某个文件写入新的信息。用户可以选择用覆盖原来内容的方式或和在文件的末尾追加新信息的方式写入信息。当要退出时输入“#”即可。(2)系统采用二级文件目录。设置主目录(MFD)和用户文件目录(UFD),分别以文件的方式保存在磁盘中。在主目录中有注册用户的用户名和另一标志该用户目录下是否有文件的指针标记。用户文件目录采用用户名作为文件名保存于磁盘,以便检索时方便对应。在用户文件目录中保存着该目录下所有文件的文件名称、保护码、文件长度。(3)该系统大量使用高级语言中的文件操作函数,所以能实际看到文件的创建、写入、读出、删除等效果。2.功能设计实现总体流程 选择操作用户登录用户注册退出在MFD中找到该用户
6、?初始化命令关键字输入操作命令删除文件读文件写文件创建文件删除文件打开文件改变权限保存当前主目录显示文件继续操作执行?开始结束结束Y N N Y word 文档 可自由复制编辑 3.主要数据结构 struct UFD/用户文件模块 char filename32;/文件名 int safecode;/文件保护码 long length;/文件长度*curfile=NULL;这个是用户文件模块数据结构,结构体的名字是:UFD,在结构体里面定义了三个成员,filename,safecode,length,分别用于存储用户文件的名字,文件保护码,文件的长度,*curfile=NULL;,这是一个结构
7、体类型的指针,开始初始化为 NULL.struct MFD/主文件模块 char username32;/存放用户名 bool filepoint;/用户目录下的文件指针,false 表示目录为空,true 为该用户目录中有文件*curuser=NULL,*elseuser=NULL;这个是主文件模块的数据结构,有两个成员,username,filepoint,分别用于存放用户名,用户目录下面的文件指针.*curuser=NULL,*elseuser=NULL;这两个是主文件的结构体变量,用于访问结构体里面的数据成员 4.主要功能模块 1.int LoginDisplay()/登陆选项操作函数
8、 2.bool Login(int SELETE)/用户登陆,注册函数 3.void DisplayUFD()/打印用户信息,包括用户的各个文件 4.void ByeFile(bool BOOL)/注销函数,调用次函数用户可以退出系统 5.bool ClearUserFile()/用户要将自己的注册目录从系统彻底删除 6.void ClearUserMes()/删除用户全部信息 7.void DeleteUser()/删除用户注册目录的操作 8.void CreatFile()/在当前用户目录下创建文件 9.void DeleteFile()/删除当前目录下一个文件的操作 10.bool Qu
9、eryModElse(bool BOOL,bool&flag)/查询其它用户目录下文件的文件 11.bool QueryMod(bool BOOL)/查询权限 12.bool WriteRight(int len,bool BOOL)/查看是否已经正确地写入到该文件信息中,是则返回真值 13.void WriteLengthToFile(int Len,bool BOOL)/将文件长度写入文件管理模块中 14.void WriteFile()/向文件写入信息的操作 15.void ReadFile()/读文件函数 16.void ChangeMod()/修改某文件的执行权限 17.void E
10、xecute(int i,int len,int cmdset)/执行命令函数 word 文档 可自由复制编辑 18.void Command()/读取用户输入的命令,并将其转换成系统能识别的命令 5小组成员及分工 负责人:姓名 模 块 黄新潮 组长分配任务,总结实验心得,分析流程图,给组员讲解 王强 对源程序加以注释、修改 张蒙 对源程序读取,运行,截图,完善 四、文件系统功能模块详细设计流程图 1.int LoginDisplay()/登陆选项操作函数 Y N Scanf SELETE_1 Return SELETE_1 0=SELETE_1LOGIN.exe End Cout error
11、 图 4 ByeFile word 文档 可自由复制编辑 5.bool ClearUserFile()/用户要将自己的注册目录从系统彻底删除 6.void ClearUserMes()/删除用户全部信息 Name=username.exe Remove Name Update(False)MFD(图 4.1)End 图 6 ClearUserMes Begin N Y Y N Begin File=username.exe File EOF Temp=Malloc(UFD)Fread(Temp,UFD,1,file)Remove Temp-file Return True End 图 5 Cl
12、earUserFile word 文档 可自由复制编辑 7.int DeleteUser()/删除用户注册目录的操作 8.void CreatFile()/在当前用户目录下创建文件 N Other N Y|yY Y Begin Buffer Scanf Ch Fread(NewFile,UFD,1,username.exe)Server&Set Buffer Cout error End 图 8 CreatFile Can Write Ch Scanf Buffer Cout Ture NewFile=Malloc(UFD)Other Y Y|y End 图 7 DeleteUser Begi
13、n ch Scanf ch R R=ClearUserFile(图 5)ClearUserMes(图 6)Return 1 word 文档 可自由复制编辑 9.void DeleteFile()/删除当前目录下一个文件的操作 Other N Y|y N Y Y Begin Ture?Ch Scanf Ch Remove Buffer End 图 9 DeleteFile Search UFD(图 2.1)Name.exe Update(False)UFD(图 4.1)word 文档 可自由复制编辑 10.bool QueryModElse(bool BOOL,bool&flag)/查询其它用户
14、目录下文件的文件 N N N N Y Y Y 31|33 Y Y N N Y Begin Temp.File=Buffer Cout error Fread(Temp,UFD,1,user.exe)Return True End 图 10 QueryModElse EOF?Temp?Return False Temp=Malloc(UFD)BOOL 32|33 word 文档 可自由复制编辑 11.bool QueryMod(bool BOOL)/查询权限 N N Y Y N Y N N N Y Y Begin Username.exe EOF Fread(temp,UFD,1,usernam
15、e.exe)Return True Else=Malloc(MFD)End 图 11 QueryMod buffer temp=Malloc(UFD)EOF Fread(Else,MFD,1,Login.exe)Username=Else Ture QueryModElse(图 10)Return False word 文档 可自由复制编辑 12.bool WriteRight(int len,bool BOOL)/查看是否已经正确地写入到该文件信息中,是则返回真值 N Y N N Y Y N Y N N Y Y Begin Username.exe EOF Fread(temp,UFD,1,
16、username.exe)Length=len Return False End 图 12 WriteRight temp=Malloc(UFD)Buffer Fwrite(temp,UFD,1,outfilelocate.exe)outfilelocate.exe Length+len EOF Buffer Fread(temp,UFD,1,username.exe)BOOL Remove username.exe outfilelocate.exe-username.exe Return Ture word 文档 可自由复制编辑 13.void WriteLengthToFile(int
17、Len,bool BOOL)/将文件长度写入文件管理模块中 14.void WriteFile()/向文件写入信息的操作 N N 2 Other Y Y 2 1 Y Y N N Begin Buffer End Get char 图 14 WriteFile Scanf Chmod Chmod QueryMod(true)(图 11)True?Char!=#Fput(char,buffer)Get char Char!=#Fput(char,buffer)WriteLength ToFile(图 11)Cout error N Y Y Y N N Begin LOGIN.exe Fread(E
18、lse,MFD,1,LOGIN.exe)End Cout error 图 13 WriteLengthToFile Else=Malloc(MFD)EOF WriteRight(图 12)True?word 文档 可自由复制编辑 15.void ReadFile()/读文件函数 16.void ChangeMod()/修改某文件的执行权限 Other Y N Y|y Begin True?Scanf Mod End Cout error 图 16 ChangeMod Printf Mod Test Ch Search UFD(图 2.1)Scanf ch Update UFD(图 4.1)Re
19、move username.exe outfilelocate.exe-username.exe N Y Y Y N N Begin True?Putchar(ch)End Cout error 图 15 ReadFile Fgetchar(buffer)Buffer QueryMod(False)(图 12)EOF?word 文档 可自由复制编辑 17.int Execute(int i,int len,int cmdset)/执行命令函数 9 8 7 6 5 4 2 3 1 N Y N Y Begin Cmdi!=0 Bufferi=Cmdi End Cout error 图 17 Exe
20、cute ListAllFile Buffer?ChangeMod(图 16)ByeFile(图 4)OpenFile Return Temp cmdset DeleteUser(图 7)CreatFile(图 8)DeleteFile(图 9)ReadFile(图 15)WriteFile(图 14)word 文档 可自由复制编辑 18.void Command()/读取用户输入的命令,并将其转换成系统能识别的命令 五、实验运行结果/*文件名:Simple_file_system.c*功 能:简单文件管理系统模拟程序 */#include#include#include#include#in
21、clude conio.h#include#define NULL 0#define keynum 10 Y N Y N Y N Y Begin 1 Scanf cmd End 图 18 Command Bufferi=cmdi|len-1 Cmdset=0|mid 二分查找命令编号 Cmdset EndIt?Execute(图 17)word 文档 可自由复制编辑#define getspace(type)(type*)malloc(sizeof(type)/宏定义 申请内存 char cmd64;/存放用户输入命令 char buffer36;/char user32;/存放当前登陆的用户
22、名 typedef char ALFA12;ALFA KWORDkeynum;/-struct UFD/用户文件管理模块 char filename32;/文件名 int safecode;/文件保护码 long length;/文件长度*curfile=NULL;/-struct MFD/用户登陆信息管理模块 char username32;/用户名 bool filepoint;/用户目录下的文件指针,false 表示目录为空,true 为该用户目录中有文件*curuser=NULL,*elseuser=NULL;typedef UFD UFD;/重命名 typedef MFD MFD;v
23、oid main();/-void KeyWord()/初始化命令关键字 strcpy(KWORD 1,bye);/用户注销命令 strcpy(KWORD 2,chmod);/改变文件的执行权限 strcpy(KWORD 3,close);/删除用户注册信息 strcpy(KWORD 4,create);/在当前目录下创建一个文件 strcpy(KWORD 5,delete);/删除当前用户目录下的一个文件 strcpy(KWORD 6,list);/显示当前注册目录下的所有文件信息 strcpy(KWORD 7,open);/打开文件 strcpy(KWORD 8,read);/读文件信息
24、strcpy(KWORD 9,write);/向文件写入新的信息 /-int LoginDisplay()/登陆选项操作函数 int SELETE_1=0;/定义整型数存放选项 do /循环控制 cout *请选择操作*n1、用户登陆 2、用户注册 0、退出SELETE_1;/输入要选择的命令 while(SELETE_12);/选项判断 system(cls);/清屏 return SELETE_1;/返回选项数 /-bool Login(int SELETE)/用户登陆,注册函数 FILE*fp,*fp1,*fp2;/定义文件 char name12;/定义数组存放登录名 switch(S
25、ELETE)/switch 选择 case 1:/用户登陆 if(fp=fopen(LOGIN.exe,rb)=NULL)/打开用户注册目录管理文件 coutn 错误:不能打开登陆文件。endl;/显示错误 getch();/读取结束符 system(cls);/清屏 return false;/返回 curuser=getspace(MFD);/用户名申请空间 coutname;/输入用户登陆名 while(!feof(fp)/检查该用户是否合法 fread(curuser,sizeof(MFD),1,fp);/文件读取 if(strcmp(curuser-username,name)=0)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 一个 简单 文件系统 详细 设计 操作系统 课程设计

限制150内