操作系统 文件系统 实验程序_第1页
操作系统 文件系统 实验程序_第2页
操作系统 文件系统 实验程序_第3页
操作系统 文件系统 实验程序_第4页
操作系统 文件系统 实验程序_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

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

文档简介

—实验目Create、delete、open、close、read、writeMDMDUFAF#defineN10#defineL#defineS6structmfd_type{ intuaddr;struct{charfname[20];charfattr[10]; intaddrf;struct{charfname[20];charfattr[10];intrecordl;charfstatue;//1:0:打开intreadp;intintfdph[N*L];//寄存文献在磁盘上的第一种空间编号intfdpt[N*L];//寄存文献在磁盘上的最末一种空间编号intdisk[400];//寄存磁盘空闲块号intdiskt,diskh;//空闲块的尾、首指针最末structmfd_typemfd[N];structufd_typeufd[N*L];structuof_typeuof[N*S];inttemp,mi,ni,uno,ucounter;voidcreate(charcfname[20],intcrecordl,char{intwhile((cltemp1<cltemp2)&&(strcmp(ufd[cltemp1].fname,cfname)!=0)){while((cltemp1<cltemp2)&&(strcmp(ufd[cltemp1].fname,"")!=0))cltemp1++;{while((cltemp1<cltemp2)&&(strcmp(uof[cltemp1].fname,"")!=0))cltemp1++;{if(disk[diskh]!=-{printf("%s\n","}elseprintf("%s\n","}elseprintf("%s\n","1,不能建文献}elseprintf("%s\n","2,不能建文献}elseprintf("%s\n","voidopen(charpfname[20],char{intcltemp1=uno*L,cltemp2=(uno+1)*L;intwhile((cltemp1<cltemp2)&&(strcmp(ufd[cltemp1].fname,pfname)!=0))cltemp1++;{while((cltemp3<cltemp4)&&(strcmp(uof[cltemp3].fname,pfname)!=0))cltemp3++;{if(uof[cltemp3].fstatue==0)printf("%s\n","文献已打开!");elseprintf("%s\n","此文献正在建立,不能打开!");}{

if(strcmp(ufd[cltemp1].fattr,ooptype)!=0)printf("%s\n","{

printf("%s\n","}}

{}}

printf("%s\n","printf("%s\n","voidwrite(charwfname[20],int{intcltemp1=uno*L,cltemp2=(uno+1)*L;intwhile((cltemp3<cltemp4)&&(strcmp(uof[cltemp3].fname,wfname)!=0))cltemp3++;if(strcmp(uof[cltemp3].fname,wfname))printf("");//在已开文{{printf("%s\n","{}}

{{if(disk[diskt]==-{}}}}voidread(charrfname[20],int{intwhile((cltemp1<cltemp2)&&(strcmp(uof[cltemp1].fname,rfname)!=0))cltemp1++;{printf("%s%d%s\n","第",uof[cltemp1].readp,"块读");while((cltemp2!=disk[frd])&&(disk[frd]!=-1))frd=disk[frd]; elseprintf("%s\n","文献未打开不能读voidclose(char{intwhile((cltemp1<cltemp2)&&(strcmp(uof[cltemp1].fname,cofname)!=0))cltemp1++;{switch(cltemp2){}}

case1:printf("%s\n","写文献结束符。");//case0:strcpy(uof[cltemp1].fname,"");printf("%s\n","voiddeletef(char{intcltemp1=uno*L,cltemp2=(uno+1)*L;intwhile((cltemp1<cltemp2)&&(strcmp(ufd[cltemp1].fname,dfname)!=0))cltemp1++;{while((cltemp3<cltemp4)&&(strcmp(uof[cltemp3].fname,dfname)!=0))cltemp3++;if(strcmp(uof[cltemp3].fname,dfname)==0)strcpy(uof[cltemp1].fname,"");}

printf("%s\n","void{int {printf("顾客名为%s的顾客拥有的文献:\n",mfd[temp].uname);for(temp1=temp*L;temp1<(temp+1)*L;temp1++){if{ }} } int{intcharfname[20],cfattr[10],ooptype[10],chtemp[10];intrecordl,rreadl;intcharmun[20],inst[10],insts[10],instta[8][10];{}{}{}printf("请输入文献目录表(顾客名和顾客首地址)e/E0为结束。\n");{if(((chtemp,"e")==0)||(strcmp(chtemp,"E")==0))break;}{printf("请输入第%d个顾客的目录表。\n"printf("请输入顾客目录表(文献名文献属性(r/w)文献统计长度文献首地址,输e/Ee00为结束。\n");for(temp=temp1*{if((strcmp(chtemp,"e")==0)||(chtemp,"E")==0)break;;}}{printf("请输入第%d个顾客的已开文献表。\n"printf("%s\n","请输入顾客已开文献表,e/Ee0000为结束。\n文献名(r/w)文献统计长度文献状态(0/1,文献读 for(temp=temp1*S;temp<(temp1+1)*S;temp++){if((strcmp(chtemp,"e")==0)||(strcmp(chtemp,"E")==0))break;}}{printf("%s\n","请输入顾客名 { while((inst[mi]!='(')&&(mi<chlen)){insts[mi]=inst[mi];mi++;} while((mmi<=7)&&(strcmp(instta[mmi],insts)!=

温馨提示

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

评论

0/150

提交评论