- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实用标准文案
精彩文档
《操作系统》课程实验
实验课题:模拟实现磁盘调度算法
姓 名:****
学 号:*****
年级班级:08级信息与计算科学
教学班级:操作系统
专业方向:08信本软件方向
指导教师:
实验时间:2010-12
一、实验名称:模拟实现磁盘调度算法
1 实验目的:a、观察、体会操作系统的磁盘调度方法,并通过一个简单的磁盘调度模拟程序的实现,加深对磁盘调度的理解。b、提高实际动手编程能力,为日后从事软件开发工作打下坚实基础。
2 实验要求:a、使用模块化设计思想来设计。b、给出主函数和各个算法函数的流程图。c、学生可按照自身条件,随意选择采用的算法。
二、 实验算法分析 总流程图
三、 实验内容及实验步骤
1 实验内容
a、模拟实现磁盘调度算法:FCFS,最短寻道优先,电梯算法(实现其中之一种以上)。
b、磁道请求服务顺序由用户输入(可通过从指定的文本文件(TXT文件)中取出)。
2 实验步骤
1) 打开microsoft vasual C++ 6.0
“开始”菜单— 所有程序—单击“microsoft vasual C++ 6.0”,进入创建页面。
2)单击标题栏“文件”选择“新建”进入界面如下:
选择‘工程,win32 console application’编辑工程名称‘zhuxuemin4’存储在d盘,创建‘创建新工作区’确定。
3)创建文件:单击标题栏“文件”选择“新建”进入界面类似于上面的界面。
4)在建好的文件中加入附件中的源程序,并进行编译。
四、 实验原始记录及结果分析
1 先来先服务调度算法
2 最短寻道优先调度算法
3 电梯调度算法
五、 参考代码
#includestdio.h
#includeiostream.h
#includestring.h
#includemath.h
const int MAXQUEUE=200; //定义请求队列最大长度//磁道号请求结构体定义
typedef struct TRACK_Node
{ int iGo; //要访问的磁道号
int iVisited; //磁道是否已经访问标志(1:已访问;0:末访问)}TRACK;
TRACK queue[MAXQUEUE]; //磁道号请求队列数组
int iReqNum=0; //磁道访问请求数
int iStart=0; //磁头初始位置
int iNow=0; //磁头当前位置
int iSum=0; //总移动磁道数
int iInput; //用户当前输入的整数
char sFileName[20]; //文件名
void Init() //初始化函数
{int i;
for(i=0;iMAXQUEUE;i++)
{ queue[i].iGo=-1; //设置要访问的磁道号为不可能的数-1,以区别正常请求磁道号queue[i].iVisited=0; //设置磁道是否已经访问标志为0:末访问} } //void Init()
void Reset() //重置访问标志、磁头当前位置、总移动磁道数
{ int i;
for(i=0;iiReqNum;i++)
{ queue[i].iVisited=0; //设置磁道是否已经访问标志为0:末访问
} printf( \n 请输入磁头的初始磁道号(整数): );
scanf(%d,iStart); //从标准输入获取用户当前输入的磁头初始位置
iNow=iStart; //磁头当前位置
iSum=0; //总移动磁道数 } //void Reset()
int ReadTrackFile() //读入磁道号流文件
{ FILE *fp;
int iTemp;
cout \n 请输入磁道号流(文本)文件名(注意:包括后缀名): ;
cinsFileName; //从标准输入获取用户当前输入的文件名
if((fp=fopen(sFileName,r))==NULL)
{ coutendl 错误:磁道号流文件 sFileName 打不开,请检查文件名和路径!!endl; return -1; } else
{ while(!feof(fp)) //将文件中输入的磁道号依次存入磁道号请求队列数组
{ fscanf(fp,%d ,iTemp);
queue[iReqNum].iGo=iTemp;
iReqNum++; //磁道访问请求数 } } //if((fp=fopen(sFileName,r))==NULL)
return 0
您可能关注的文档
- 铝热还原法+碳热还原法+氢还原法冶炼金属钒.doc
- 绿色壁垒地外文翻译.doc
- 绿色节能环保班级评比.doc
- 绿色贸易壁垒对浙江省农产品出口地影响与对策分析报告.doc
- 绿色荧光蛋白(GFP)原核表达分析报告.doc
- 绿色制造企业的一体化实用标准体系地多目标决策与组合评价与衡量.doc
- 马尔可夫预测算法.doc
- 马克思主义军事理论与时俱进特征浅析.doc
- 麦当劳独特地特许经营模式.doc
- 麦肯锡行业分析报告实用模板.doc
- 计及电动汽车移动储能动态电价的微电网优化调度研究及解决方案.pdf
- 浅谈电动汽车充电桩绝缘智能化自检装置的设计与应用 .pdf
- 浅谈电动汽车公共充电桩布局方案评价方法.pdf
- 浅谈基于弹性响应的电动汽车快充电价定价策略 汽车充电桩有序充电.pdf
- 浅谈光储充一体化社区的有序充电策略及解决方案.pdf
- 晚期肾透明细胞癌系统性治疗中国专家共识(2024版).pptx
- 中国膀胱癌保膀胱治疗多学科诊治协作共识(2022版).pptx
- 成人心血管外科手术体外循环患者血液管理指南.pptx
- 下尿路修复重建移植物应用规范中国专家共识.pptx
- 中国儿童急性非静脉曲张性上消化道出血诊治指南(2024).pptx
文档评论(0)