模拟文件系统的设计与实现Word文档下载推荐.docx
- 文档编号:19125251
- 上传时间:2023-01-04
- 格式:DOCX
- 页数:15
- 大小:39.85KB
模拟文件系统的设计与实现Word文档下载推荐.docx
《模拟文件系统的设计与实现Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《模拟文件系统的设计与实现Word文档下载推荐.docx(15页珍藏版)》请在冰豆网上搜索。
rmdir
列出文件目录:
dir退出:
exit
开始
选择操作
创建文件
删除文件
读文件
写文件
创建文件夹
删除文件夹
删除子目录
显示当前子目录
创建子目录
更改目录
退出
系统执行流程图
退出
3.详细设计
主要数据结构:
#defineMEM_D_SIZE1024*1024ame,name))
break;
}
if(j<
MSD+2)/*文件已经存在*/
return(-4);
for(i=2;
i<
MSD+2;
i++)/*找到第一个空闲子目录*/
{
if(cur_dir->
directitem[i].firstdisk==-1)
if(i>
=MSD+2)/*无空目录项*/
return(-2);
if>
=MOFN)/*打开文件太多*/
return(-3);
for(j=ROOT_DISK_NO+1;
j<
DISK_NUM;
j++)/*找到空闲盘块j后退出*/
if(fat[j].em_disk=='
0'
)
if(j>
=DISK_NUM)
return(-5);
fat[j].em_disk='
1'
;
/*将空闲块置为已经分配*/
/*-----------填写目录项-----------------*/
strcpy(cur_dir->
directitem[i].name,name);
cur_dir->
directitem[i].firstdisk=j;
directitem[i].size=0;
directitem[i].next=j;
directitem[i].property='
/*---------------------------------*/
fd=open(name);
return0;
}
intopen(char*name)
{
inti,j;
i++)/*文件是否存在*/
if(!
strcmp(cur_dir->
directitem[i].name,name))
=MSD+2)
return(-1);
/*--------是文件还是目录-----------------------*/
if(cur_dir->
directitem[i].property=='
)
/*--------文件是否打开-----------------------*/
for(j=0;
MOFN;
j++)
strcmp[j].name,name))
MOFN)/*文件已经打开*/
=MOFN)/*文件打开太多*/
/*--------查找一个空闲用户打开表项-----------------------*/
if[j].firstdisk==-1)
/*--------------填写表项的相关信息------------------------*/
[j].firstdisk=cur_dir->
directitem[i].firstdisk;
strcpy[j].name,name);
[j].size=cur_dir->
directitem[i].size;
++;
/*----------返回用户打开表表项的序号--------------------------*/
return(j);
intclose(char*name)
inti;
for(i=0;
i++)
strcmp[i].name,name))
=MOFN)
/*-----------清空该文件的用户打开表项的内容---------------------*/
strcpy[i].name,"
"
);
[i].firstdisk=-1;
[i].size=0;
;
intwrite(intfd,char*buf,intlen)
char*first;
intitem,i,j,k;
intilen1,ilen2,modlen,temp;
/*----------用$字符作为空格#字符作为换行符-----------------------*/
charSpace=32;
charEndter='
\n'
len;
if(buf[i]=='
$'
buf[i]=Space;
elseif(buf[i]=='
#'
buf[i]=Endter;
/*----------读取用户打开表对应表项第一个盘块号-----------------------*/
item=[fd].firstdisk;
/*-------------找到当前目录所对应表项的序号-------------------------*/
directitem[i].firstdisk==item)
temp=i;
/*-存放当前目录项的下标-*/
/*------找到的item是该文件的最后一块磁盘块-------------------*/
while(fat[item].item!
=-1)
item=fat[item].item;
/*-查找该文件的下一盘块--*/
/*-----计算出该文件的最末地址-------*/
first=fdisk+item*DISKSIZE+[fd].size%DISKSIZE;
/*-----如果最后磁盘块剩余的大小大于要写入的文件的大小-------*/
if[fd].size%DISKSIZE>
len)
strcpy(first,buf);
[fd].size=[fd].size+len;
cur_dir->
directitem[temp].size=cur_dir->
directitem[temp].size+len;
else
for(i=0;
[fd].size%DISKSIZE);
{/*写一部分内容到最后一块磁盘块的剩余空间(字节)*/
first[i]=buf[i];
}
/*-----计算分配完最后一块磁盘的剩余空间(字节)还剩下多少字节未存储-------*/
ilen1=len-[fd].size%DISKSIZE);
ilen2=ilen1/DISKSIZE;
modlen=ilen1%DISKSIZE;
if(modlen>
0)
ilen2=ilen2+1;
/*--还需要多少块磁盘块-*/
for(j=0;
ilen2;
{
for(i=ROOT_DISK_NO+1;
i++)/*寻找空闲磁盘块*/
{
if(fat[i].em_disk=='
break;
}
if(i>
=DISK_NUM)/*--如果磁盘块已经分配完了-*/
return(-1);
first=fdisk+i*DISKSIZE;
/*--找到的那块空闲磁盘块的起始地址-*/
if(j==ilen2-1)/*--如果是最后要分配的一块-*/
for(k=0;
k<
len-[fd].size%DISKSIZE)-j*DISKSIZE;
k++)
first[k]=buf[k];
else/*-如果不是要最后分配的一块--*/
DISKSIZE;
first[k]=buf[k];
fat[item].item=i;
/*--找到一块后将它的序号存放在上一块的指针中-*/
fat[i].em_disk='
/*--置找到的磁盘快的空闲标志位为已分配-*/
fat[i].item=-1;
/*--它的指针为-1(即没有下一块)-*/
/*--修改长度-*/
intread(intfd,char*buf)
intlen=[fd].size;
inti,j,item;
intilen1,modlen;
ilen1=len/DISKSIZE;
modlen=len%DISKSIZE;
if(modlen!
=0)
ilen1=ilen1+1;
/*--计算文件所占磁盘的块数-*/
first=fdisk+item*DISKSIZE;
/*--计算文件的起始位置-*/
ilen1;
if(i==ilen1-1)/*--如果在最后一个磁盘块-*/
for(j=0;
len-i*DISKSIZE;
buf[i*DISKSIZE+j]=first[j];
else/*--不在最后一块磁盘块-*/
item=fat[item].item;
/*-查找下一盘块-*/
first=fdisk+item*DISKSIZE;
intdel(char*name)
inti,cur_item,item,temp;
i++)/*--查找要删除文件是否在当前目录中-*/
cur_item=i;
/*--用来保存目录项的序号,供释放目录中-*/
=MSD+2)/*--如果不在当前目录中-*/
directitem[cur_item].property!
='
)/*--如果删除的(不)是目录-*/
i++)/*--如果文件打开,则不能删除,退出-*/
return(-2);
item=cur_dir->
directitem[cur_item].firstdisk;
/*--该文件的起始盘块号-*/
while(item!
=-1)/*--释放空间,将FAT表对应项进行修改-*/
temp=fat[item].item;
fat[item].item=-1;
fat[item].em_disk='
item=temp;
/*-----------------释放目录项-----------------------*/
directitem[cur_item].sign=0;
directitem[cur_item].firstdisk=-1;
strcpy[cur_item].name,"
directitem[cur_item].next=-1;
directitem[cur_item].property='
directitem[cur_item].size=0;
主函数:
intmain()
FILE*fp;
charch;
chara[100];
charcode[11][10];
charname[10];
inti,flag,r_size;
char*contect;
contect=(char*)malloc(MAX_WRITE*sizeof(char));
if((fp=fopen("
"
rb"
))==NULL)
printf("
Youhavenotformat,Doyouwantformat(y/n)"
scanf("
%c"
&
ch);
if(ch=='
y'
initfile();
printf("
Successfullyformat!
\n"
else
return0;
enter();
print();
show();
strcpy(code[0],"
exit"
strcpy(code[1],"
create"
strcpy(code[2],"
open"
strcpy(code[3],"
close"
strcpy(code[4],"
write"
strcpy(code[5],"
read"
strcpy(code[6],"
del"
strcpy(code[7],"
mkdir"
strcpy(code[8],"
rmdir"
strcpy(code[9],"
dir"
strcpy(code[10],"
cd"
while
(1)
%s"
a);
11;
if(!
strcmp(code[i],a))
break;
switch(i)
case0:
ize;
{
printf("
contect[i]);
}
printf("
\t\n"
}
show();
case6:
//删除文件
scanf("
name);
flag=del(name);
if(flag==-1)
printf("
Error:
\nThefilenotexit!
elseif(flag==-2)
\nThefileisopened,pleasefirstcloseit!
elseif(flag==-3)
\nThedeleteisnotfile!
else
Successfullydelete!
}
程序运行截图:
4.心得体会
在设计的过程中,我查询了不少相关资料,不断地发现问题、提出问题、解决问题。
用C做程序开发语言,让我重新认识了C的基础,在新语言不断出现并发展迅速的今天,重新体会到C的基础性、重要性,以及面对过程,面对函数式的编程方式。
在对自己所编写的源程序段的纠错的过程中,使我更好的理解了操作系统中文件系统的理论知识,同时在编程时用到了模块化的设计思想,这种编程方法可以使我们的编程更简单,可以使我们的查错与纠错变得更加方便。
总的来说通过这次的设计学习使我学到了很多在平时的学习中学不到的很多东西,对操作系统有了更深一层的了解,同时也提高了C语言的能力,由于时间以及个人知识的问题,因此有很多的地方还需要改进。
在以后的学习中还要更加努力。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 模拟 文件系统 设计 实现
![提示](https://static.bdocx.com/images/bang_tan.gif)