文件资料的管理与计算机操作实验报告,文件管理实验报告.doc

文件管理实验报告文件管理实验报告

昆明理工大学信息工程与自动化学院学生实验报告

( 2011 —2012 学年 第 二 学期 )

课程名称:操作系统 开课实验室:信自楼444 2012 年5 月28日

年级、专业、班计科101学号201010803116姓名李力成绩实验项目名称文件管理指导教师杨云飞教师评语

教师签名:

年 月 日一、实验目的

用编写和调试一个简单的文件系统,模拟文件管理的。从而对各种文件操作命令的实质内容和执行过程有比较深入的了解。要求设计一个的文件系统,。 开始

输入用户名

在MFD中找到该用户名

显示该用户名UFD中所有文件

初始化AFD

操作

命令

CREATE DELTET OPEN CLOSE READ WRITE

保护当前文件目录

结束

主要数据结构

界面采用VC6 MFC环境开发

#define MAXFILE 20 //每个用户最多保存20个文件

#define MAXUSER 10 //假想文件系统最多支持的人数

#define BLOCKSIZE 32 //虚拟磁盘中物理块为每块32字节

#define DISKSIZE BLOCKSIZE*1000 //虚拟磁盘容量为1000*32=32K

struct UFD //说明文件项的结构数组

{

char FileName[15];

char Time[16]; //文件建立或修改时间 如2003/5/6 12:00

bool IsExist; //文件是否存在,删除时标为0

bool IsShared; //共享标记,共享文件可被其它用户所访问

bool AttrRead; //文件是否可读

bool AttrWrite; //文件是否可写

bool AttrExecute; //文件是否可执行

HTREEITEM treeNode; //用于树控件显示的结点句柄

USHORT FileLen; //文件占用字节数

USHORT BlockNum; //文件占用的物理块数

USHORT FileLink[100];//文件物理块地址数组,每块32字节,限定一个文件最大100*32=3200字节

};

struct MFD

{

char UserName[10]; //主目录用户名

bool IsExist; //该用户否存在

UFD ufd[MAXFILE]; //用户文件数组

USHORT nItem;//UFD个数

};

struct HEADBLOCK

{

BYTE pStack; //堆栈指针

SHORT pBlock[10]; //块号 pBlock[10]是下一个盘块号逻辑地址

};

struct BLOCK //虚拟磁盘的物理块数据结构

{

union{

BYTE block[32];        //一块为32字节

HEADBLOCK HeadInfo;

};

};

struct FAT

{

BLOCK SuperBlock; //超级块,指示第一个空闲块逻辑号

USHORT MaxOpen; //该用户同时可打开的最大文件数

USHORT UserNum; //最户数

MFD Mfd[MAXUSER]; //最多可支持10个用户

};

//空闲块成组链接法

bool OpenList[MAXUSER][MAXFILE]; //描述文件是否打开的布尔型数组

FAT FileFAT;           //描述文件记录项的FAT结构

CFile FATIO; //负责和VDISK.DAT打交道的文件句柄

CString CurrentUser; //当前登录的用户名

Int CurrentID; //前前登录的用户标识号

说明:本实验采用模拟文件结构的方法,把记录用户帐号,用户文件和磁盘块的信息用当前目录下的VDISK.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
操作系统实验(含实验报告) 1、进程调度 2、作业调度 3、主存空间的分配与回收 4、文件系统 一、 实验目的 用高级语言编写和调试一个进程调度程序,以加深对进程的概念及进程调度算法的理解。 二、实验内容和要求 编写并调试一个模拟的进程调度程序,采用“简单时间片轮转法”调度算法对五个进程进行调度。 每个进程有一个进程控制块( PCB)表示。进程控制块可以包含如下信息:进程名、到达时间、需要运行时间、已运行时间、进程状态等等。 进程的到达时间及需要的运行时间可以事先人为地指定(也可以由随机数产生)。进程的到达时间为进程输入的时间。 进程的运行时间以时间片为单位进行计算。 每个进程的状态可以是就绪 W(Wait)、运行R(Run)两种状态之一。 就绪进程获得 CPU后都只能运行一个时间片。用运行时间加1来表示。 如果运行一个时间片后,进程的已占用 CPU时间已达到所需要的运行时间,则撤消该进程,如果运行一个时间片后进程的已占用CPU时间还未达所需要的运行时间,也就是进程还需要继续运行,此时应分配时间片给就绪队列中排在该进程之后的进程,并将它插入就绪队列队尾。 每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的 PCB,以便进行检查。 重复以上过程,直到所要进程都完成为止。 三、实验主要仪器设备和材料 硬件环境:IBM-PC或兼容机 软件环境:C语言编程环境 四、实验原理及设计方案 1、进程调度算法:采用多级反馈队列调度算法。其基本思想是:当一个新进程进入内在后,首先将它放入第一个队列的末尾,按FCFS原则排队等待高度。当轮到该进程执行时,如能在该时间片内完成,便可准备撤离系统;如果它在一个时间片结束时尚为完成,调度程序便将该进程转入第二队列的末尾,再同样地按FCFS原则等待调度执行,以此类推。 2、实验步骤: (1)按先来先服务算法将进程排成就绪队列。 (2)检查所有队列是否为空,若空则退出,否则将队首进程调入执行。 (3)检查该运行进程是否运行完毕,若运行完毕,则撤消进程,否则,将该进程插入到下一个逻辑队列的队尾。 (4)是否再插入新的进程,若是则把它放到第一逻辑队列的列尾。 (5)重复步骤(2)、(3)、(4),直到就绪队列为空。 。。。。。。。。。。。。。。。。。。。。。。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值