操作系统实验三(题目四)实验报告_李旦兰_20083308

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

操作系统实验三

实验报告

姓名李旦兰学号20083308 班级软件0802 指导教师那俊

实验名称存储管理

开设学期2010 – 2011第一学期

评定成绩

评定人签字

评定日期

东北大学软件学院2010年11月

实验三_B

一.实验题目

用高级语言编写和调试一个简单的文件系统,模拟文件管理的工作过程。(题目四)二.实验目的

(1)进一步认识虚拟存储器的工作原理;

(2)进一步认识文件系统的内部功能以及内部实现;

(3)深入理解操作系统中文件系统的理论知识,加深对教材中的重要算法的理解;

(4)掌握操作系统的原理及实现方法,提高综合运用各专业课知识的能力。

三.实验内容以及要求

(1)设计一个支持n个用户的简单二级文件系统,每个用户可保存m个文件,用户在一次运行中只能打开一个文件;

(2)采用二级或二级以上的多级文件目录管理;

(3)对文件应设置存取控制保护方式,如“只能执行”、“允许读”、“允许写等”;(4)系统的外部特征应接近于真实系统,可设置下述文件操作命令:Login 用户登录;Dir 列出文件目录; Create 建立文件;Delete 删除文件; Read 读文件;Write 写文件;Open 打开文件; Close 关闭文件。

(5)通过键盘使用该文件系统,系统应显示操作命令的执行结果。

四.实验环境

操作系统:Windows 7

开发语言:VC++

开发工具:Microsoft Visual C++ 2008 Express Edition

五.程序设计思想

通过阅读实验指导书,整理出实验大体的思路,确定实体以及它们之间的关系。实体关系有三张表(主文件目录,用户文件目录以及打开文件目录)、命令服务和用户构成。用户负责输入命令。命令服务实现命令检查以及调用相关模块执行相应的命令功能。

(1)主文件目录(MFD),包括用户名和文件目录指针;

struct user MFD[1]={{"0",0}};//MFD(用户名文件目录指针)

(2)用户文件目录(UFD),包括文件名、保护码以及文件长度;

struct file UFD[10];//用户文件目录(UFD-文件名保护码文件长度)

(3)打开文件目录(AFD),包括打开文件名、打开保护码以及读写指针。采用数组形式存储打开的文件,数组每个元素保存一个打开文件的信息

struct file AFD[5]={{"0",0,0,0},{"0",0,0,0},{"0",0,0,0},{"0",0,0,0},{"0",0,0,0}};//运行文件目录(AFD)——一次运行用户可以打开个文件

在此模拟文件管理系统中可以实现的操作有:

(1)用户登录:login,用户通过登录从而使用系统功能;

(2)创建文件:create,创建一个指定名字的新文件,即在目录中增加一项,不考虑

文件的内容。对于重名文件给出错误信息。

(3)删除文件:delete,当没在用户使用指定文件时,将其删除。文件不存在时给出错误信息。

(4)打开文件:open,打开用户文件目录中已创建的文件,显示打开成功。若文件不存在,则提示用户该输入有误。

(5)关闭文件:close,关闭用户文件目录中存在并且已打开的文件,显示关闭成功。若文件不存在,则提示用户该输入有误。

(6)读取文件:read, 系统先判断在用户文件目录上是否存在该文件,若存在则判断该文件是否已打开,接着判断该文件的权限,若能读取则显示“该文件的状态是正在读”,若权限不够,则提示该错误信息。

(7)写入文件:write, 若要写的文件既不是在用户文件目录上不存在的也不是未打开的,则接着判断该用户是否有权限写入文件,若有权限,则显示出“文件的状态是正在写”,若无权限,则提示该错误信息。

(8)列出文件目录:dir,显示出该目录下的所有文件。

(9)退出登录:exit,输入exit命令可退出当前用户登录,使其他用户登录。六.实验系统结构

1.实验算法流程图

开始

初始化数据

用户输入命令

分析命令

命令表中有该命令?

显示错误信息

创建删除读取显示列表写入查询保存关闭执行命令执行命令

退出程序

(exit)

2.算法设计

(1)该程序可分为以下几个模块:

void login();

void dir();

void create();

void delet();

void open();

void close();

void write();

void save();

(2)主要函数模块分析

1)创建文件:其中重点使用了strcmp函数,它是比较两个字符串的大小,返回比较的结果。

void create()

{ char name[10];

int i,j=0,flag;

for(i=0;i<10;i++)

{ if(!strcmp(UFD[i].name,"0"))

j++;}

if(j>9)

{ cout<<"文件夹己满,请先删除"<

dir();}

else{

do{cout<<"请输入文件名:"<

cin>>name;

flag=0;

for(i=0;i<10;i++)

{ if(!strcmp(UFD[i].name,name))//如果有重名的文件

{ cout<<"文件名重复,请重新输入"<

flag=1; break;}

}

}while(flag==1);

for(i=0;i<10;i++)

{ if(!strcmp(UFD[i].name,"0"))//找到第一个空的文件

{ strcpy(UFD[i].name,name);

do

{ cout<<"请输入保护码(选择-2,0-可读,-可写,-可读写):"<

cin>>UFD[i].code;

if(UFD[i].code!=0&&UFD[i].code!=1&&UFD[i].code!=2)

cout<<"输入错误,重新输入保护码"<

}while(UFD[i].code!=0&&UFD[i].code!=1&&UFD[i].code!=2);

cout<<"请输入文件长度(选择数字):"<

cin>>UFD[i].size;

cout<<"己建立文件"<

break;}

}

dir();

}

}

2)写文件:

相关文档
最新文档