- 1、本文档共23页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
操作系统模拟实现单级目录单级索引的索引文件系统
操作系统模拟实现单级目录、单级索引的索引文件系统
一、 课程设计的性质和目的
操作系统课程设计是计算机专业的专业课程,通过课程设计使学生进一步巩固课堂所学知识,全面熟悉、掌握操作系统的基本设计方法和技巧,进一步提高分析问题、解决问题及上机操作能力,为将来从事计算机工作打下一定的专业基础。
二、 设计课题
课题一:模拟实现单级目录的FAT文件系统
基本思路:用二进制文件空间模拟磁盘空间,用文件块操作模拟磁盘块
操作。
基本设计要求:1、实现如下文件系统功能(过程或函数):
a、 打开文件系统 FILE *OPENSYS(char *filename);
b、 关闭文件系统 int CLOSESYS(FILE *stream);
c、 显示目录 void LISTDIR(void);
d、 建立文件 int FCREATE(char *filename);
e、 删除文件 int FDELETE(char *filename);
f、 打开文件 int FOPEN(char *filename);
g、 关闭文件 int FCLOSE(int fileid);
h、 文件块读 int FREAD(void *ptr, int n, int fileid);
i、 文件块写 int FWRITE(void *ptr, int n, int fileid);
j、 判断文件结束 int FEOF(int fileid);
k、 获取文件指针 long FGETPOS(int fileid);
l、 设置文件指针 int FSETPOS(int fileid, long offset);
m、 取得文件长度 long FGETLEN(char *filename);
2、提供文件系统创建程序
3、有功能检测模块
4、为简化程序设计,假定目录区域大小固定。
文件系统空间划分:
可以使用的C语言文件操纵函数:
FILE *fopen(const char *filename, const char *mode);
int fclose(FILE *stream);
int fseek(FILE *stream, long offset, int whence);
long ftell(FILE *stream);
size_t fread(void *ptr, size_t size, size_t n, FILE *stream);
size_t fwrite(const void *ptr, size_t size, size_t n, FILE *stream);
课题二:模拟实现单级目录、单级索引的索引文件系统
使用链接域将同一文件的各索引块按顺序连接起来;其余各项同课题一。
三、 课程设计报告要求
1、设计报告要求A4纸打印成册;
2、使用学院统一的封面;
3、课程设计报告每人一份,必须包含如下几个方面的内容:
1) 基本设计思想;
2) 主要数据结构;
3) 主要实施流程;
4) 所有源代码;
5) 课程设计总结与体会。
四、 分组及选题办法
1、按学号顺序一人一组,学号为奇数者为课题一,偶数者为课题二。
2、成绩考核按个人课题完成情况、设计报告质量及对课程设计的态度等综
合评定。
五、设计进度安排
1、 讲课及上机调试时间安排:
上机时间:十八周 周一至周三每天上午8:00—12:00
2、 其余时间:查阅资料,确定方案,设计课题相关程序。
3、 个人答辩,交课程设计报告。
主要数据结构提示:
1、单级目录FAT文件系统:
1) 常量
#define BlockSize 512
#define DirSize 32
2) 保留扇区结构
struct ReserveBlock{
int sysblocknum; /*文件系统总扇区数*/
int resblocknum; /*保留扇区扇区数*/
int fatblocknum; /*FAT表扇区数*/
int rootblocknum; /*根目录区扇区数*/
char fillchar[BlockSize-4*sizeof(int)];/*填充字节*/
};
3) 目录结构
char filename[11]; /*文件名限长11个字符*/
char fillchar[DirSize-4*sizeof(int)-sizeof(long int)-11]; /*填充
字节*/
long filelen; /*文件长度*/
int year,month,day; /*日期*/
int firstblockaddr; /*文件首块扇区号*/
};
4) FCB(文件控制块)结构
struct FCBBlock{
int fileid; /*文件标识*/
struct DirBlock
文档评论(0)