二级文件系统
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
《计算机操作系统》
课程设计
题目:二级文件系统
专业:计算机科学与技术
班级:
姓名:
学号:
指导教师:
时间:2011.6.01---2011.6.10
2011年6 月13日
一、实验内容
为Linux系统设计一个简单的二级文件系统。要求做到以下几点:
1.可以实现下列几条命令:
login用户登录
dir 列目录
create创建文件
delete 删除文件
open 打开文件
close 关闭文件
read 读文件
write 写文件
2.列目录时要列出文件名,物理地址,保护码和文件长度
二、实验目的
通过一个简单多用户文件系统的设计,加深理解文件系统的内部功能及内部实现。
三、开发环境
Windows操作系统
Microsoft Visual C++
四、分析设计
实验原理
通过程序模拟Linux文件系统,用一个二进制文件(FileSystem.disk)来模拟磁盘.设计一个多用户的二级文件系经统、实现一般的创建文件、目录,删除文件、目录,切换目录,打开、关闭文件、读写文件等操作。
文件系统,包含格式化,显示文件(目录),创建文件等几个简单命令的实现,而且能完成超级块的读写,节点的读写等过程. 本文件系统采用两级目录,其中第一级对应于用
户账号,第二级对应于用户账号下的文件。另外,为了简单本文件系统未考虑文件共享、文件系统安全以及管道文件与设备文件等特殊内容。
1.程序执行流程图:
2.数据块的分配和回收
设计FileSystem类负责管理磁盘空间和磁盘内存I节点,负责对磁盘空间和磁盘数据进行优化管理。并提代接口言方法供用户或程序调用。
五、打印的源程序及附上的注释
#include "xd.h" //文件管理
void createFile(char fileName[],int length,char fileKind[]); //创建文件
void fileWrite(char fileName[]); //写文件
void fileCat(char fileName[]); //读文件
void fileRen(char fileName[],char rename[]); //重命名文件
void fileClose(char fileName[]); //关闭已打开的文件
void delFile(char fileName[]); //删除文件
int requestDist(int &startPostion,int maxLength); //磁盘分配查询
void initDisk(); //初始化磁盘
void freeDisk(int startPostion); //磁盘空间释放
//用户管理
void userCreate();
int login();
int userID=-1; //用户登录的ID号,值为-1时表示没有用户登录
//用户注册
void userCreate()
{
char c;
char userName[10];
int i;
if(used { cout<<"请输入用户名:"; for(i=0;c=getch();i++) if(c==13) break; else userName[i]=c; printf("%c",c); } userName[i]='\0'; for(i=0;i { if(!strcmp(userTable[i].userName,userName)) { cout<<"\n"; cout<<"该用户名已存在,创建用户失败\n"; //system("pause"); return; } } strcpy(userTable[used].userName,userName); cout<<"\n"; cout<<"请输入密码:"; for(i=0;c=getch();i++) { if(c==13) break; else userTable[used].password[i]=c; printf("*"); } userTable[used].password[i]='\0'; cout<<"\n"; cout<<"创建用户成功\n"; used++; //system("pause"); } else { cout<<"创建用户失败,用户已达到上限\n"; //system("pause"); } fflush(stdin); } //登录 int login() { char name[10],psw[10]; int i,times; cout<<"请输入用户名:"; for(i=0;c=getch();i++) { if(c==13) break; else name[i]=c; printf("%c",c); } name[i]='\0'; for(i=0;i { if(!strcmp(userTable[i].userName,name)) break; } if(i==used) { cout<<"\n您输入的用户名不存在\n"; //system("pause"); return -1; } for(times=0;times<3;times++) { memset(psw,'\0',sizeof(psw)); cout<<"\n请输入密码:"; for(i=0;c=getch();i++) { if(c==13) break; else psw[i]=c; cout<<"*"; } printf("\n"); for(i=0;i { if(!strcmp(psw,userTable[i].password)) { printf("用户登录成功\n"); //system("pause"); break; }