操作系统原理----文件虚拟管理_第1页
操作系统原理----文件虚拟管理_第2页
操作系统原理----文件虚拟管理_第3页
操作系统原理----文件虚拟管理_第4页
操作系统原理----文件虚拟管理_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

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

文档简介

1、操作系统原理课程设计报告姓 名: 班 级: 学 号: 指导老师: 年 月 日17目录一、操作系统原理课程设计的目的与要求11、目标:12、要求:1二、简述课程设计内容、主要功能和实现环境21、主要功能:22、主要设计内容:23、运行环境:2三、任务的分析、设计、实现和讨论31、任务的分析32、任务的设计与实现(分别给出系统总控和本人负责实现的算法流程图与说明)43、操作过程和结果分析74、思考题的解答和讨论11四、操作系统课程设计小结(收获、不足与建议)12五、附录(主要源程序和运行结果的清单)13一、操作系统原理课程设计的目的与要求1、目标:随着社会信息量的极大增长,要求计算机处理的信息与日

2、俱增涉及到社会生活的各个方面。因此,文件管理是操作系统的一个极为重要的组成部分。学生应该运用独立的高级语言来编写一个简单和可操作的文件操作系统,模拟文件管理的工程运作。从而对各种文件操作指令的实质内容和过程原理有比较深刻的了解,掌握他们的实施方法加深理解课堂上讲授过的知识。我小组需要实施的文件管理是任务六,包括文件系统的:建立,关闭以及写的功能。2、要求:(1)设计一个多(n)用户的文件系统,每个用户户最多保存m个文件。(2)限制用户在一次运行中只能打开一个文件。(3)系统应能检查打入命令的正确性,出错是要能够显示出错的原因。(4)对文件的权限必须有保护措施,如果只能运行,允许读,允许写等。在

3、每次打开文件时,根据本次打开的要求,设置保护级别,即可有二级保护。(5)对文件的操作表述中必须有以下指令: 建立: create() 删除: delete() 打开: open() 关闭 close() 读: read() 写: write()二、简述课程设计内容、主要功能和实现环境此次实验的基本内容就是完成一个可执行的文件系统管理的操作系统。1、主要功能:一个由10个用户的操作系统,每个用户最多保存10个文件,一次运行中用户可打开5个文件。系统对相应的操作判断操作性的正确与否并进入相应的菜单运行。为使用者提供了操作的方便,不需要敲代码来实现程序的功能。该程序设置了用户登入,创建文件,打开文件

4、,关闭文件,写文件以及对用户文件总体概况的结果显示。另外,为了更加真实的反应该系统的对文件可执行程度的判断,添加了保护码控制文件的读写操作的安全性。2、主要设计内容:(1)本实习设计一个10个用户的文件系统,每个用户最多可保存10个文件,每个文件名都为单个字符,一次运行中用户可打开5个文件。(2)程序采用二级文件目录,即设置了主文件目录(MFD)和用户文件目录(UFD)。前者应包含文件主(即用户)及他们的目录区指针;后者应给出每个主文件占有的文件目录,即文件名,保护码,文件长度以及他们存放的位置等。另外为打开文件设置了运行文件目录(AFD),在文件打开时应填入打开文件号,本次打开保护码和读写指

5、针等。(3)为了便于实现,对文件的读写作了简化,在执行读写命令时,只修改读写指针,并不进行实际文件的读写操作。3、运行环境: 课程设计的实现环境是在WINXP2000下运行Microsoft Visual C+和在WINXP2000下运行WORD2003。三、任务的分析、设计、实现和讨论1、任务的分析(1)、整个源程序采用一维数组来定义。用户登录采用最简单的选择型,总共设置10位用户,登陆即选择相对应的用户名。文件目录的检索是使用了简单的线性搜索,而没有采用哈希等有效的算法。该设计的程序的保护码形式采取简单的单字符,分为3种,其中分别是0-只可读,1-只可写,2-可读写。另外对于文件打开与关闭

6、的操作设置了单字节的标识符有,0-文件已关闭,1-文件未关闭。(2)、整个程序的布局应该是有7个函数,分别为Incitialize()初始化函数,create()建立文件函数,open()对文件的打开函数,close()对文件的关闭函数,write()对文件的写函数,Show()显示概况信息的函数和main()主函数。每个函数都是实现改程序的重要环节。创建文件函数决定了整个程序的关键它需要准确的定义与算法。在定义函数时定义结构体,把需要的变量定义完整,整个程序主要还是通过数组的运用来完成的。通过数组来衔接主目录和用户目录来执行之后的操作。(3)、主文件目录与用户目录的结构图如下图1-1:UFD

7、MFD用户名文件目录指针用户名文件目录指针用户名文件目录指针文件名保护码文件长度文件名文件名保护码文件长度文件名图1-1 文件系统目录结构图(4)、打开文件目录如下图图1-2所示:打开文件号打开保护码读写指针图1-2 打开文件目录图2、任务的设计与实现(分别给出系统总控和本人负责实现的算法流程图与说明)(1)、在编译程序实现功能的任务中,我主要负责最初的结构体定义,对关键变量的初始化以及对全程序的修改及完善。定义结构体以及变量是程序的开头,也是关键因素之一,对程序编译时所采用的算法进行了决定性作用。(2)、定义的结构体以一维数组的形式定义,便于组员之间相互理解与编译。结构体定义:a、Mfd用户

8、目录对象名类型说明username9Char型数组用户名CountInt对用户数的计数器Ufd UFDFilenum文件结构体数组文件目录数组Mfd MFDUsernum 数组用户数的数组b、Afd 文件目录文件打开目录对象名类型说明OpenNoInt打开文件号ProInt保护码Afd AFDOpennum数组打开文件数c、Ufd文件目录对象名类型说明FilenameChar文件名Proint文件保护码Lengthint文件长度FlagInt文件打开标识号Afd AFDOpennum数组打开文件数Ufd UFDFilenum数组文件数量(3)、初始化定义:int i,j=0;两个变量分别代表M

9、FD和UFD中所指的当前位置MFDi.UFDj.filename=NULL;文件名设为空MFDi.UFDj.flag=0;打开标识符为关闭MFDi.UFDj.length=0;长度为0MFDi.UFD=3;保护码不存在MFDi.UFDj.AFD->OpenNo=0;打开目录号为0(4)、操作模拟流程:打开文件号j打开保护码AFDUFDMFD用户名用户k用户名文件i保护码文件长度文件名(5)、详细说明:在设计方面,是按数组套数组的思想进行定义。即Mfd数组中套Ufd数组,再Ufd数组中套Afd数组。这样不需要指针的定义,也能很有效的找到用户所对的文件以及文件和所对的文件打开号。但

10、是这样也有缺陷,需要定义很大的数组容量,占用了很多空间,另外,因为定义的是字符型而没有定义字符型数组,导致对于文件名的定义执行和输出只能实现单字节。(6)、总体设计概要:a、结构体定义完成后,将定以后的变量以及数组等信息放入各个函数进行编译操作,做为最主要的开头核心函数Create()创建文件函数,编译者按照定义的结构体把要求的3位安全码改成了1位,由“0-2”三个数字实现对文件的读写操作的保护,同时用了多个循环体来对操作者可能出现的误操作做了相应合理的处理,另外,“MFDk.UFDi.AFDi.OpenNo=count+;”对打开函数中打开号的处理也提前完成。Create的返回值为“retu

11、rn count;”的值要在打开函数中赋值给打开号。Open和Close函数由另一位成员完成,其中Open()打开函数按照要求进行,一个循环体“while(i<Filenum)”打开文件“MFDk.UFDi.flag=1;”为标识码的设置,初始为0现在打开后改为1。Close()关闭函数中“if(MFDk.UFDi.flag=1”判断标识码,“MFDk.UFDi.flag=0;”文件关闭后将标识码的值改为”0”。我和另一位成员一起完成write()写文件函数的编译,“MFDk.UFD=1|MFDk.UFD=2”和“if(MFDk.UFDi.flag=1)”;两句判断语

12、是否可写入和是否文件已经打开将保护码和标识码的作用发挥出来,并且写函数添加了将文件长度增加的功能“length=len+MFDk.UFDi.length;”Show()显示信息函数将之前保存的信息输出,以简明概要的输出该文件管理系统对文件操作后的信息,Show()函数主要需要之前函数的保存工作,之前函数编辑成员未能将内容保存在各自的函数中,在之后的修改中得以实现,Write函数中 对长度的保存:“MFDk.UFDi.length=length;”Create函数中 对文件名的保存:“MFDk.UFDi.filename=name;”对保护码的保存:“MFDk.UFD=pro;”对长度

13、的保存:“MFDk.UFDi.length=length;”打开码的保存:“MFDk.UFDi.AFDi.OpenNo=count+;”主函数main的编译成员,是将用户函数与主函数合并,整个程序中没有用户函数user(),并导致MDF结构体所定义的username9和count没有利用。将主界面显示格式设为菜单操作,这对于思考题的要求打到了效果。此外,其定义了9 个用户并通过9个if语句判断用户名的存在性运用switch语句施行对界面的选择菜单操作。b、程序的主要的流程结构如下所示,图1-5Close()Write()Create()否选择用户名是否存在该用户报告无此用户重新选择初始化运行文

14、件表AFD输入菜单号是什么命令关闭程序open()退出Show()建立文件写程序显示当前目录保存当前文件目录打开文件开始图1-5 文件系统的总流程图3、操作过程和结果分析(1)用户登录:在操作界面中选择用户登录(0-9)以及错误操作如图1-6所示图1-6 选择用户图1-7用户输入错误重新输入(2)建立文件,选择1进入建立文件的界面,输入文件的名字,保护码以及长度即可,可以建立多个文件,文件b长度210保护码2;文件a长度341保护码1;文件名m长度93保护码0。以及错误操作创建同名文件图1-8 进入用户6并建立文件b图1-9 在用户6下建立文件a图1-9 在用户6下建立文件m图1-10 文件存

15、在(3)打开文件,可以选择2号键来打开已经建立的文件;如果打开没有建立的文件会显示。分别打开b、a、m和未建立的文件c。图1-11 成功打开文件b图1-12 成功打开文件a图1-13 成功打开文件m图1-14 打开不存在的文件效果图(4)关闭文件,选择菜单3号,即可关闭已经建立并且打开的文件。如果关闭不存在的文件就会提示该文件不存在。分别关闭b、a、m以及未建立的文件d。图1-15 关闭文件b图1-16 关闭文件a图1-17 关闭文件m图1-18 打开没有建立的文件(5)写文件,选择4即可写文件,在写文件的时候需输入文件名,所需写入文件信息的长度,对被关闭的文件写入和被保护不能写入的文件以及对

16、不存在的文件写入。分别对b文件写入长度310,总长度520;对a文件写入510,总长度810;文件m写保护不能写入。再执行菜单3,关闭b文件,再对b文件写入。图1-19 写文件b图1-20 写文件a图1-21 写文件m图1-22 写未建立文件q图1-23 写已被关闭的文件b (6)显示文件,输入5,系统会打印出当前用户已经输入的文件信息。 图1-24 显示文件信息(7)用户更换,如果想更换用户的话,输入6即可。图1-25 用户更换(8)退出系统,按7即可退出程序。4、思考题的解答和讨论对于思考题1,本次课程设计程序已经使用了菜单方式操作,每幅屏幕要为用户提供足够的选择信息,不需要打入冗长的命令

17、。该方式使整个操作界面简洁明了,还提高了操作效率,同时也为使用者提供了方便。具体代码如下:printf("%s","请输入对文件的命令:n1:建立n2:打开n3:关闭n4:写n5:显示文件n6:用户切换n7:退出n");scanf("%d",&order);while(order!=7)switch(order)case 1:count=create(use,count);break;case 2:open(use);break;case 3:close(use);break;case 4:Write(use);break;c

18、ase 5:Show(use);break;case 6:main();printf("%s","n请输入对文件的命令:n1:建立n2:打开n3:关闭n4:写n5:显示文件n6:用户切换n7:退出n");scanf("%d",&order);对于思考题3,认为应该设置一个访问权值,类似该课程设计中的保护码,2是可以访问上级菜单和下级菜单,1是只可以访问下一级菜单,0是只可以访问上级菜单。通过设置共享码来实现同一级的共享化,类似这次课程设计的flag打开标识码。校长教务处科研处校务处一 系十系教学行政科教学研究所研究生科科研科情

19、报资料室技术服务部财务科基建科房管科总务科一一一实验室一二教研室一三研究室一一教研室一一三实验室一二教研室一三研究室一一教研室四、操作系统课程设计小结(收获、不足与建议)五、附录(主要源程序和运行结果的清单)主要函数代码:void Incitialize()/初始化int i,j=0;for(i=0;i<Usernum;i+)MFDi.UFDj.filename=NULL;MFDi.UFDj.flag=0;MFDi.UFDj.length=0;MFDi.UFD=3;MFDi.UFDj.AFD->OpenNo=0;int create(int k,int count)int

20、 i=0,length,pro;char name;printf("%s","请输入文件名(单字符):");scanf("%s",&name);/getchar();while(i<Filenum)if(MFDk.UFDi.filename!=NULL)if(MFDk.UFDi.filename=name)printf("%s","该文件已经存在!");return count;i+;else break;if(i=Filenum)printf("%s",&qu

21、ot;用户文件已满,不可再创建!");return count;printf("%s","请输入文件的长度:");scanf("%d",&length);printf("%s","请输入文件的保护码(0-只可读 1-只可写 2-可读写):");scanf("%d",&pro);for(i=0;i<Filenum;i+)if(MFDk.UFDi.filename=NULL)MFDk.UFDi.filename=name;MFDk.UFDi.len

22、gth=length;MFDk.UFD=pro;MFDk.UFDi.AFDi.OpenNo=count+;printf("%s","创建成功!");break;return count;void open(int k)int i=0;int pro,OpenNo;char name;printf("%s","请输入文件名:");scanf("%s",&name);while(i<Filenum)if(MFDk.UFDi.filename=name)printf("

23、;输入该文件保护码:");scanf("%s",&pro);printf("该文件的打开码为:");printf("%dn",MFDk.UFDi.AFDi.OpenNo);printf("文件已经打开!");MFDk.UFDi.flag=1;return;elsei+;if(i=Filenum)printf("%s","不存在该文件!n");void close(int k)int i=0;char name;printf("请输入文件名:&quo

24、t;);scanf("%s",&name);while(i<Filenum)if(MFDk.UFDi.filename=name)if(MFDk.UFDi.flag=1)printf("%s","文件已经成功关闭!n");MFDk.UFDi.flag=0;return;else printf("文件本已处于关闭状态!n");return;else i+;if(i=Filenum)printf("%s","不存在该文件!n");void Write(int k)int i=0;int len,length;char name; printf("%s","请输入文件名:");scanf("%s",&name);while(i<Filenum)if(MFDk.UFDi.filename=name)if(MFDk.UFD=1|MFDk.UFD=2)if(MFDk.UFDi.flag=1)printf("写入文件信息的长度:");scanf("%d",&

温馨提示

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

评论

0/150

提交评论