实验二--文件系统模拟设计.doc
《实验二--文件系统模拟设计.doc》由会员分享,可在线阅读,更多相关《实验二--文件系统模拟设计.doc(15页珍藏版)》请在咨信网上搜索。
1、实验二 文件系统模拟设计 作者: 日期:15 个人收集整理 勿做商业用途实验二 文件系统模拟设计一、实验目的通过一个简单多用户文件系统的设计,加深理解文件系统的内部功能及内部实现。二、实验内容为linux系统设计一个简单的二级文件系统。要求做到以下几点: (1)可以实现下列几条命令(至少4条); login用户登录 dir 列文件目录 create创建文件 delete删除文件 open 打开文件 close关闭文件 read 读文件 write写文件 (2)列目录时要列出文件名、物理地址、保护码和文件长度;(3)源文件可以进行读写保三、实验内容指导提示(1)首先应确定文件系统的数据结构:主目
2、录、子目录及活动文件等。主目录和子目录都以文件的形式存放于磁盘,这样便于查找和修改。 (2)用户创建的文件,可以编号存储于磁盘上.如file0,file1,file2.。.并以编号作为物理地址,在目录中进行登记。程序设计思想参考程序设计(1)设计思想本系统是模拟实现多用户多目录的文件系统(8个用户),在系统出现登录后 ,输入用户与口令,在用户登录系统后,可建立文件卷,将用户输入的文件保存在指定的文件中.系统的命令与其命令的具体实现,此模拟系统共提供了上述命令,并根据命令的含义与要求,用C+编程来完成所有具体操作。该系统可以模拟完成用户的登陆和验证,列出文件和目录,新建目录,改变目录,创立和编写
3、文件,删除文件和退出系统等功能。【注:在linux下用g+编译C+】 (2)主要数据结构用户结构:账号与密码结构typedef struct users char name8;char pwd10;users;本系统有8个默认的用户名,前面是用户名,后面为密码,用户登陆时只要输入正确便可进入系统,否则提示失败要求重新输入。users usrarray8 =usr1”,usr1, ”usr2,”usr2”,usr3”,”usr3”,”usr4”,”usr4,”usr5”,”usr5,usr6”,usr6”,usr7,”usr7,usr8”,usr8,;(3)数据结构说明a)文件结构链表struc
4、t fnode char filenameFILENAME_LENGTH;int isdir;int isopen;char content255;fnode parent;fnode *child;fnode *prev;fnode *next;b)函数介绍fnode *initfile(char filename,int isdir);/初始化文件或目录void createroot();/建立系统根目录int run();系统运行int findpara(char topara);对参数进行处理bool chklogin(char users, char pwd);检查账号与口令void
5、 help();命令列表int mkdir();建立目录int create();建立文件int read();读取文件int write();写入文件int del();删除文件int cd();切换目录int dir();文件与目录列表(4)各模块流程图(5)、模拟文件系统参考程序清单#include stdio。h”#include ”iostream.hinclude ”string。hinclude ”iomanip.h”#define FILENAME_LENGTH 10 /文件名称长度define COMMAND_LENGTH 10 /命令行长度#define PARA_LENG
6、TH 30 /参数长度/账号结构typedef struct users char name8;char pwd10;users;/文件结构struct fnode char filenameFILENAME_LENGTH;int isdir;int isopen;char content255;fnode parent;fnode child;fnode *prev;fnode next;;/账号users usrarray8 =”usr1,”usr1”,usr2”,”usr2,usr3,usr3,usr4,”usr4”,usr5,”usr5”,”usr6”,”usr6”,usr7”,”us
7、r7,”usr8,usr8”,;fnode initfile(char filename,int isdir);void createroot();int run();int findpara(char *topara);bool chklogin(char *users, char pwd);void help();int mkdir();int create();int read();int write();int del();int cd();int dir();fnode *root,recent,*temp,ttemp;char paraPARA_LENGTH,commandCOMM
8、AND_LENGTH,tempparaPARA_LENGTH,recentparaPARA_LENGTH;/创建文件与目录结点fnode initfile(char filename,int isdir) fnode node=new fnode; strcpy(node-filename,filename); nodeisdir=isdir;nodeisopen=0;node-parent=NULL; node-child=NULL;node-prev=NULL;nodenext=NULL;return node;/创建文件存储结点void createroot () recent=root
9、=initfile(”/,1); rootparent=NULL; rootchild=NULL; rootprev=root-next=NULL; strcpy(para,”/”); int mkdir() temp=initfile(” ”,1);cintempfilename;if(recent-child=NULL) tempparent=recent; temp-child=NULL; recent-child=temp; tempprev=tempnext=NULL; else ttemp=recent-child;while(ttempnext) ttemp=ttempnext;
10、 if(strcmp(ttemp-filename,tempfilename)=0&ttemp-isdir=1) printf(”对不起,目录已存在!”); return 1; ttemp-next=temp; temp-parent=NULL; tempchild=NULL; temp-prev=ttemp; tempnext=NULL; return 1;int create() temp=initfile(” ”,0);cintemp-filename;cintempcontent;if(recent-child=NULL) temp-parent=recent; tempchild=N
11、ULL; recentchild=temp; tempprev=temp-next=NULL; cout”文件建立成功!”next) ttemp=ttempnext; if(strcmp(ttemp-filename,temp-filename)=0&ttemp-isdir=0) printf(”对不起,文件已存在!”); return 1; ttempnext=temp; tempparent=NULL; temp-child=NULL; temp-prev=ttemp; tempnext=NULL; cout”文件建立成功!”endl; return 1;int dir()int i=0,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验 文件系统 模拟 设计
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。