您好,欢迎访问三七文档
实验四文件系统实验一.目的要求1、用高级语言编写和调试一个简单的文件系统,模拟文件管理的工作过程。从而对各种文件操作命令的实质内容和执行过程有比较深入的了解。2、要求设计一个n个用户的文件系统,每次用户可保存m个文件,用户在一次运行中只能打开一个文件,对文件必须设置保护措施,且至少有Create、delete、open、close、read、write等命令。二.例题:1、设计一个10个用户的文件系统,每次用户可保存10个文件,一次运行用户可以打开5个文件。2、程序采用二级文件目录(即设置主目录[MFD])和用户文件目录(UED)。另外,为打开文件设置了运行文件目录(AFD)。3、为了便于实现,对文件的读写作了简化,在执行读写命令时,只需改读写指针,并不进行实际的读写操作。4、算法与框图:①因系统小,文件目录的检索使用了简单的线性搜索。②文件保护简单使用了三位保护码:允许读写执行、对应位为1,对应位为0,则表示不允许读写、执行。③程序中使用的主要设计结构如下:主文件目录和用户文件目录(MFD、UFD)打开文件目录(AFD)(即运行文件目录)MDFUFDAFD用户名文件名打开文件名文件目录指针保护码打开保护码用户名文件长度读写指针文件目录指针文件名··文件系统算法的流程图如下:三.实验题:1、增加2~3个文件操作命令,并加以实现。(如移动读写指针,改变文件属性,更换文件名,改变文件保护级别)。代码如下://1、增加2~3个文件操作命令,并加以实现。(如移动读写指针,改变文件属性,更换文件名,改变文件保护级别)。#includeiostream#includestring#includeconio.husingnamespacestd;structTYPE_UFD{stringFile_Name;boolRead;boolWrite;boolExecute;intLength_File;};structTYPE_MFD{stringUser_Name;TYPE_UFD*Pointer;};structTYPE_AFD{intFile_ID;boolRead;boolWrite;boolExecute;intPointer;};classTYPE_FILE_SYSTEM{public:voidInitial(void);voidStart(void);private:int_Number_Users;int_Number_Files;int_MaxNumber_Open_Files;TYPE_MFD*_MFD;TYPE_UFD*_UFD;TYPE_AFD*_AFD;};voidTYPE_FILE_SYSTEM::Initial(void){_Number_Users=10;_Number_Files=10;_MaxNumber_Open_Files=5;_UFD=newTYPE_UFD[_Number_Users*_Number_Files];_MFD=newTYPE_MFD[_Number_Users];inti=0;for(i=0;i_Number_Users;i++){_MFD[i].Pointer=&(_UFD[i*_Number_Files]);}_AFD=newTYPE_AFD[_MaxNumber_Open_Files];_MFD[0].User_Name=zaq;_UFD[0].File_Name=file1.txt;_UFD[0].Length_File=10;_UFD[0].Read=true;_UFD[0].Write=false;_UFD[0].Execute=true;_UFD[1].File_Name=file2.txt;_UFD[1].Length_File=20;_UFD[1].Read=true;_UFD[1].Write=false;_UFD[1].Execute=false;for(i=2;i_Number_Files;i++){_UFD[i].File_Name=;_UFD[i].Length_File=-1;_UFD[i].Read=false;_UFD[i].Write=false;_UFD[i].Execute=false;}}voidTYPE_FILE_SYSTEM::Start(void){intUser_ID;inti,temp_int;stringtemp;charchoice;intNumber_Open_Files;stringUser_Name;stringCommand;TYPE_UFD*UFD;do{do{cout已创建用户名为zaq\n指令有:createdeleteopendirdiropenwritereadlogoutshutdown\n\n;cout请输入用户名:;cinUser_Name;for(User_ID=0;User_ID_Number_Users;User_ID++){if(_MFD[User_ID].User_Name==User_Name)break;}if(User_ID==_Number_Users)cout用户名错误,请再次输入.endl;}while(User_ID==_Number_Users);cout欢迎登录,User_Name!endl;UFD=_MFD[User_ID].Pointer;for(i=0;i_MaxNumber_Open_Files;i++){_AFD[i].File_ID=-1;}Number_Open_Files=0;do{coutC:\\User_Name;cinCommand;if(Command==dir){coutendl;cout打开用户User_Name的文件endl;cout\tState\tLength\tFilenameendl;for(i=0;i_Number_Files;i++){if(UFD[i].Length_File!=-1){cout\t;if(UFD[i].Read==true)coutR;elsecout-;if(UFD[i].Write==true)coutW;elsecout-;if(UFD[i].Execute==true)coutE;elsecout-;cout\t;coutUFD[i].Length_File;cout\t;coutUFD[i].File_Nameendl;}}coutendl;}elseif(Command==diropen){coutendl;cout打开用户User_Name的文件endl;cout\tState\tOpenFilenameendl;for(i=0;i_MaxNumber_Open_Files;i++){if(_AFD[i].File_ID!=-1){cout\t;if(_AFD[i].Read==true)coutR;elsecout-;if(_AFD[i].Write==true)coutW;elsecout-;if(_AFD[i].Execute==true)coutE;elsecout-;cout\t;coutUFD[_AFD[i].File_ID].File_Nameendl;}}coutendl;}elseif(Command==create){for(i=0;i_Number_Files;i++)if(UFD[i].Length_File==-1)break;if(i==_Number_Files)coutError:已有名为_Number_Files的文件.endl;else{cout请输入新文件信息:endl;cout文件名:;cintemp;UFD[i].File_Name=temp;cout文件权限:;coutRead(y/n):;do{choice=getch();}while(choice!='y'&&choice!='n');if(choice=='y')UFD[i].Read=true;elseUFD[i].Read=false;coutendl;coutWrite(y/n):;do{choice=getch();}while(choice!='y'&&choice!='n');if(choice=='y')UFD[i].Write=true;elseUFD[i].Write=false;coutendl;coutExecute(y/n):;do{choice=getch();}while(choice!='y'&&choice!='n');if(choice=='y')UFD[i].Execute=true;elseUFD[i].Execute=false;coutendl;coutLength:;cintemp_int;if(temp_int0)UFD[i].Length_File=temp_int;cout新文件UFD[i].File_Name已建立!endl;}}elseif(Command==delete){cout请输入文件名:;cintemp;for(i=0;i_Number_Files;i++)if((UFD[i].Length_File!=-1)&&(UFD[i].File_Name==temp))break;if(i==_Number_Files)cout文件名错误,请再次输入.endl;else{UFD[i].Length_File=-1;cout文件UFD[i].File_Name已删除.endl;}}elseif(Command==open){if(Number_Open_Files==_MaxNumber_Open_Files)coutError:你已经打开了Number_Open_Files文件.endl;else{cout请输入文件名:;cintemp;for(i=0;i_Number_Files;i++)if((UFD[i].Length_File!=-1)&&(UFD[i].File_Name==temp))break;if(i==_Number_Files)cout文件名错误,请再次输入.endl;else{Number_Open_Files++;for(temp_int=0;temp_int_MaxNumber_Open_Files;temp_int++)if(_AFD[temp_int].File_ID==-1)break;_AFD[temp_int].File_ID=i;_AFD[temp_int].Pointer=0;cout请定义打开方式:endl;if(UFD[i].Read==true){coutRead(y/n):;do{choice=getch();}while(choice!='y'&&choice!='n');if(choice=='y')_AFD[temp_int].Read=true;else_AFD[temp_int].Read=false;coutendl;}else_AFD[temp_int].Read=false;if(UFD[i].Write==true){coutWrite(y/n):;do{choice=getch();}while(choice!='y'&&choice!='n');if(choice=='y')_AFD[temp_int].Write=true;else_AFD[temp_int].Write=false;coutendl;}else_AFD[temp_int]
本文标题:实验四文件系统实验
链接地址:https://www.777doc.com/doc-2459798 .html