操作系统课程设计实验报告-模拟FAT文件系统.doc_第1页
操作系统课程设计实验报告-模拟FAT文件系统.doc_第2页
操作系统课程设计实验报告-模拟FAT文件系统.doc_第3页
操作系统课程设计实验报告-模拟FAT文件系统.doc_第4页
操作系统课程设计实验报告-模拟FAT文件系统.doc_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

操作系统课程设计之三设计任务:模拟os文件系统在任一os(window或者dos;也可以是在linux下,但要求能将结果演示给老师看)下,建立一个大文件,把它假象成一张盘,在其中实现一个简单的模拟os文件系统。1、在现有机器硬盘上开辟10m(共10000个盘块,每盘块大小为1k)的硬盘空间(生成一个10m的用户文件sdisk.dat即可),作为设定的硬盘空间。2、编写一管理程序sdisk,对此空间进行管理,以模拟os文件系统,要求:、盘块大小1k 、空闲盘块的管理:采用位示图法、文件空间管理:采用fat(文件分配表),每个盘块号占2个字节、目录项管理:、每个目录项占用32字节,其中前8个字节(0-7)为文件名,之后跟3个字节(8-10)的扩展名,26-27字节,存放文件的第一个盘块号,最后四个字节(28-31),存放文件长度(如果目录项对应的是下一级子目录(文件),其文件长度部分为0)、目录按文件方式管理,每个目录仅用一个盘块(即1k,最多装32个目录项)、第0个目录项为本目录,即“.”,第0个字节为“.”,即0x2e,第26-27字节指明本目录所在盘块。、第1个目录项为父目录,即“.”,第0,1个字节为“.”即0x2e,0x2e,第26-27字节指明父目录所在盘块。、每个目录实际能放下文件或子目录30项。、文件系统空间分配:、第0个盘块(1k)存放磁盘信息(可以设定为格式说明“fat32”、盘块大小,盘块数等内容)、第1个盘块起,至125盘块,共125个盘块(125k)存放fat内容、第126、127(2个)盘块,存放位示图、从第128盘块至10000盘块,皆为数据(区)盘块,其逻辑编号从0开始,至9872号数据盘块,即第0数据盘块为128号盘块,第1数据盘块为129号盘块,、第0数据盘块(即128号盘块),存放根目录(同样只用一个盘块作根目录),由于第0、1目录项为“.”(本目录), “.”(父目录),因此根目录下同样只能存放30个文件或目录,并且从第2个目录项开始。、文件或子目录数据,放在第1数据盘块及以后的数据盘块中,由用户按需要使用。3、sdisk管理程序的功能要求如下:、正常情况下,显示等待命令输入符号#、改变目录命令:#cd 目录名,改变当前工作目录,目录不存在时给出出错信息#cd .,返回上一级目录,如果是根目录,给出提示信息、生成新目录#md 目录名,创建新目录(需要更改fat内容和位示图内容)、删除目录#rd 目录名,删除目录,如果目录不存在时给出出错信息(需要更改fat内容和位示图内容)、显示目录#dir,显示指定目录下或当前目录下的信息,包括文件名、扩展名、物理地址(文件或目录第一个盘块号)、文件长度、子目录、创建新文件#createfile 文件名.扩展名 文件长度,根据文件名.扩展名,创建一个目录项(fcb),根据文件长度和位示图中空闲盘块情况,分配足够多的连续盘块,给新文件(需要更改fat内容和位示图内容)。、删除文件#delfile 文件名.扩展名,在文件所在的目录项中,将第一个字节变为0xe5,并同时修改fat内容和位示图内容;如果文件不存在,给出出错信息、文件拷贝#copyfile 老文件,新文件,为新文件创建一个目录项,并将老文件内容复制到新文件中,并同时修改fat内容和位示图内容、显示位示图内容#showbitmp,将位示图内容(已有信息部分),显示在屏幕上(按十六进制)、显示fat内容#showfat,将fat内容(已有信息部分),显示在屏幕上(按十六进制)4、程序的总体流程为:、输出提示符#,等待接受命令,分析键入的命令;、对合法的命令,执行相应的处理程序,否则输出错误信息,继续等待新命令(1、请参考“03.fat32文件系统简介.doc”中,有关文件系统的规定; 2、请参考winhex中,目录所显示的信息进行编程)/关于fat 和map表的解释/用bitset库,做map的是否判断,因为作业要求从数据块从128位开始,所以bitset的前128位被置为-1,同样fat表也是,其次,map表和fat表同样是用数组方式做保存,这样就略过了是对具体地址的操作,从数组的下标很容易的定位,关于对fat表和map表的用法1. 当要用到数据块是,查询map表(因为只做比较查询即可),查询到的未用位置置1,然后在fat表上进行相应记录,在本程序做出的规定是,当文件夹fat表做-1,若是文件则按照fat做对应的顺序记录,最后一块同样是-1结束,2. 回收的时候,是按照fat表的首项,做顺序置0,然后map也在相应位置置0#include#include#include#include#include /*/author:chenlog/enviroment:vc2008 win7/date:2011-6-5 version 1.0/*/using namespace std;const int blocknum_size=2;/盘块号大小const int block_size=1024; /一个盘块大小数const int block_num=10001; /盘块数量const int disk_size=1024*1000*10;/磁盘大小const int list_size=32;/目录项大小const int map_size=10001;/map 长度const int fatnum=125;/fat的盘块数 第块没有用const int fatlist=512;/每个盘口fat的记录数const int databeg=128;/数据项开始fat号struct fcbchar fname8;/文件名char exname3;/扩展名short fnum;/首块号int length;/文件大小, 目录则文件大小为;;struct fatidshort idfatnum*fatlist; /fat 大小512个记录 一块*fat;struct mapbitset maplist;*map;struct dirstruct fcb listlist_size+1;*filedir;int currentid=128; /当前fat号int currentdir=128; /当前目录块号初始化是+1 由于第个单元没有使用char *file; /磁盘的首地址char *filepath=myfat; /window文件保存地址file *fp; /window 文件地址string current=root;/当前路径char cmd30;/输入指令char command16;/*对文件存储器进行格式化*创建根目录*/void findbit(struct map *map)void init(struct fatid *fat)int i,j;for(i=1;idatabeg)fat-idi=0;elsefat-idi=-1;void format()bool i; fat=(struct fatid *)(file+block_size); /当前fat地址 map=(struct map *)(file+(fatnum+1)*block_size); /初始化位示图init(fat);fat-id0=9872;filedir=(struct dir *)(file+(fatnum+1+2)*block_size); /当前目录指针地址fat-id128=-1;fat-id0=9872-1;strcpy(filedir-list0.fname,.);strcpy(filedir-list0.exname,dir);filedir-list0.fnum=currentdir;filedir-list0.length=0;strcpy(filedir-list1.fname,.);strcpy(filedir-list1.exname,dir);filedir-list1.fnum=currentdir;filedir-list1.length=0;fp=fopen(filepath,w+);fwrite(file,sizeof(char),disk_size,fp);fclose(fp);printf(初始化已经完成,现在可以进行操作了!nn);/*创建子目录*/int mkdir(char *str)int i,j;int blockid;/将要创建的fat号int blockdir;/将要创建的目录块号int listnum;/目录块内编号struct fatid *flagid; struct dir *dir; /当前目录指针struct map *map;struct fatid *fat;if(strcmp(str,)=0)printf(目录名称不能为空n);return 0; dir=(struct dir *)(file+(currentdir)*block_size); map=(struct map *)(file+(fatnum+1)*block_size); fat=(struct fatid *)(file+block_size); for(i=databeg+1;imaplisti=0) break; if(iblock_num) printf(内存不足n);return 0; map-maplisti=1;/map 置即已用dir=(struct dir *)(file+(currentdir)*block_size);for(i=2;ilisti.fname,str)=0)printf(目录下有同名文件夹n);return 0;for(i=2;ilisti.fname,)=0)/有空的目录块且无重名,第一版本的时候与上面的循环放在一起,存在一个情况是前面的建立的目录删除后,直接被同名的覆盖了break;if(ilist_size)printf(内存不足n);return 0;flagid=(struct fatid *)(file+block_size);/fat 首位地址for(j=databeg+1;jidj=0)blockdir=j;break;strcpy(dir-listi.fname,str);dir-listi.fnum=blockdir;strcpy(dir-listi.exname,dir);dir-listi.length=0;dir=(struct dir *)(file+blockdir*block_size); /为新目录项创建根目录strcpy(dir-list0.fname,.);strcpy(dir-list0.exname,dir);dir-list0.fnum=blockdir;dir-list0.length=0;strcpy(dir-list1.fname,.);strcpy(dir-list1.exname,dir);dir-list1.fnum=currentdir;dir-list1.length=0;flagid-idj=-1; /修改fat 目录尾部fat-id0=fat-id0-1;printf(已经成功创建目录%s n,str);return 0;/*显示目录*/int listshow()int i,sumfile,sumdir,fl100,dr100;/fl 为文件的号数,dr为目录的号数sumfile=sumdir=0;struct dir *dir;struct fatid *fat;dir=(struct dir *)(file+currentdir*block_size);for(i=0;ilisti.length=0&(strcmp(dir-listi.fname,)!=0)&(dir-listi.fnum!=0)/为目录的drsumdir=i;sumdir+;if(dir-listi.length!=0&strcmp(dir-listi.fname,)!=0)/为目录的flsumfile=i;sumfile+;for(i=0;ilistdri.fname);for(i=0;ilistfli.fname,dir-listfli.exname);printf(n);printf(n在该目录下共有%d 个文件, %d 个文件夹nn,sumfile,sumdir-2);return 0;/*删除子目录*/int rmdir(char *str)int i;int blockid;int flag=0;/fat号int blocknum;/目录块struct fatid *fat;struct dir *dir;struct dir *flagdir;/标记目录块char c=a; /做用户交互int m=2;/从第三个子目录项开始搜索要删除的目录项情况fat=(struct fatid *)(file+block_size);dir=(struct dir *)(file+currentdir*block_size);/当前目录指针map=(struct map *)(file+(fatnum+1)*block_size);for(i=2;ilisti.fname,str)=0)/找到要删除的子目录break;if(ilist_size)printf(该文件夹下不存在%s,str);return 0;while(1)printf(是否确认?(y/n));cinc;if(c=y|c=y)|(c=n|c=n)break;if(c=n|c=n)return 0;blocknum=dir-listi.fnum;flagdir=(struct dir *)(file+blocknum*block_size);while(m!=list_size)if(strcmp(flagdir-listm.fname,)!=0)printf(该目录下有子文件或者子目录,不能删除该目录);m+;strcpy(dir-listi.fname,);/父目录dirstrcpy(dir-listi.exname,);dir-listi.fnum=0;strcpy(flagdir-list0.fname,);/要删除目录的dirstrcpy(flagdir-list0.exname,);flagdir-list0.fnum=0;strcpy(flagdir-list1.fname,);strcpy(flagdir-list1.exname,);flagdir-list0.fnum=0;map-maplistblocknum=0;fat-idblocknum=0;fat-id0=fat-id0+1;return 0;/*更改当前目录*/int changedir(char *str)int i,j;int blocknum;/当前目录位置int flagnum;/temp的目录位置struct dir * flagdir,*dir;struct fatid * fat;string strflag; /为了改当前显示的代码dir=(struct dir *)(file+currentdir*block_size);if(strcmp(.,str)=0)/判断是不是上层目录blocknum=currentdir;if(dir-list0.fnum=dir-list1.fnum)/根目录的特征return 1;currentdir=dir-list1.fnum;/改变当前目录指针flagdir=(struct dir *)(file+currentdir*block_size);/去上层的目录地址for(int j=0;jlistj.fnum=blocknum)strflag=flagdir-listj.fname;break;current=current.substr(0,(current.length()-strflag.length()-1);return 1;for(i=2;ilisti.fname,str)=0&strcmp(dir-listi.exname,dir)=0)currentdir=dir-listi.fnum;break;if(ilist_size)printf(找不到指定的目录%sn,str);return 0;current=current+str+;return 1;/*创建文件*/int create(char *str,int length)/getfilenameint i,j,l,t,k;int blockdir;int fid;/fat的首块号int flag;/文件的首块判断char name8=0;/文件名称 char exname3=0;/文件扩展名int templength; /temp文件长度struct fatid * fat;struct dir *dir;struct map *map; dir=(struct dir *)(file+(currentdir)*block_size); map=(struct map *)(file+(fatnum+1)*block_size); fat=(struct fatid *)(file+block_size); templength=length;l=strlen(str);/取文件名for(i=0;i=8)printf(文件名称过长n);return 0;/去扩展名j=0;i+;i+;/除去点k=l-i;for(j=0;jfat-id0)printf(文件超出磁盘容纳空间n);return 0; for(i=2;ilisti.fname,name)=0&strcmp(dir-listi.exname,exname)=0) printf(改文件夹下,已经有同名文件);return 0; if(strcmp(dir-listi.fname,)=0)break; if(ilist_size)printf(内存不足n);return 0;strcpy(dir-listi.fname,name);strcpy(dir-listi.exname,exname);dir-listi.length=length;flag=1;j=databeg+1;while(1)/不断循环if(map-maplistj!=1)if(!templength-)/当length全部被分配完截止break;/上一块的地址if(flag)/第一次分配是的首地址dir-listi.fnum=j;/给文件的首块map-maplistj=1;/map减少if(!flag)fat-idt=j;/fat-id0=fat-id0-1;t=j;flag=0;j+;fat-idt=-1;/fat-id0=fat-id0-1; printf(已经成功创建文件%s n,name);return 1;/*复制文件*/int cp(char *str,char *newname)int i,j,k,l,length;char name8=0;/文件名称 char exname3=0;/文件扩展名struct dir *dir;l=strlen(str);/取文件名for(i=0;il;i+)namei=stri;if(stri+1=.) break;/去扩展名j=0;i+;i+;/除去点k=l-i;for(j=0;jk;j+)if(stri=0)break;exnamej=stri;i+;if(strcmp(newname,)=0)printf(文件名不能为空n);return 0;dir=(struct dir *)(file+currentdir*block_size);for(i=2;ilisti.fname,name)=0&strcmp(dir-listi.exname,exname)=0)break;if(ilist_size)printf(找不到指定的文件%sn,str);return 0;length=dir-listi.length ;create(newname,length);/*删除文件*/int delfile(char *str)int i,j,l,k;int blocknum; /要删除的首块地址int temp;char name8=0;/文件名称 char exname3=0;/文件扩展名char c=a;struct dir *dir;struct fatid *fat;struct map *map;l=strlen(str);/取文件名for(i=0;il;i+)namei=stri;if(stri+1=.) break;/去扩展名j=0;i+;i+;/除去点k=l-i;for(j=0;jk;j+)if(stri=0)break;exnamej=stri;i+;if(strcmp(str,)=0)printf(文件名不能为空n);return 0; dir=(struct dir *)(file+(currentdir)*block_size); map=(struct map *)(file+(fatnum+1)*block_size); fat=(struct fatid *)(file+block_size); for(i=2;ilisti.fname,name)=0)&(strcmp(dir-listi.exname,exname)=0)break;if(ilist_size)printf(找不到%s 文件n,str);return 0;while(1)printf(是否确认?(y/n));cinc;if(c=y|c=y)|(c=n|c=n)break;if(c=n|c=n)return 0;blocknum=dir-listi.fnum;dir-listi.fnum=0;/把目录项还原strcpy(dir-listi.exname,);strcpy(dir-listi.fname,);dir-listi.length=0;/处理fat and map 表while(fat-idblocknum!=-1)temp=fat-idblocknum;fat-idblocknum=0;fat-id0=fat-id0+1;map-maplistblocknum=0;blocknum=temp;printf(已经成功删除%sn,str);return 0;int showbitmp()int i,j;int listblock_size=0;struct map *map; map=(struct map *)(file+(fatnum+1)*block_size);j=0;for(i=databeg+1;imaplisti=1)listj=i;j+;for(i=0;iblock_size;i+)if(listi!=0)printf( %0x,listi);if(i%10=0)printf(n);return 0;int findbit()return 0;int showfat()int i,j,flag;struct fatid *fat;int listblock_size=0;fat=(struct fatid *)(file+block_size);j=0;for(i=databeg+1;iidi!=0)listj=i;j+;j=0;flag=0;for(i=0;iblock_size;i+)if(listi!=0)printf( %0x,listi);if(flag)if(j%10=0)printf(n);flag=1;j+;return 0;/*退出系统*/int exit()fp=fopen(filepath,w+);fwrite(file,sizeof(char),disk_size,fp);fclose(fp);free(file);return 1;void welcome()/欢迎列表printf(-n);printf(n以下是使用说明n);printf(format : 对磁盘格式化.n);printf(exit : 安全退出该文件系统,保存信息.n);printf(mkdir dirname ; 创建子目录.n);printf(rmdir dirname : 删除子目录.n);printf(ls dirname : 显示当前目录下信息.n);printf(cd dirname : 更改当前目录.n);printf(create fil

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论