实验报告六--磁盘调度算法.doc

实验报告六--磁盘调度算法.doc

ID:55704563

大小:57.00 KB

页数:17页

时间:2020-05-25

实验报告六--磁盘调度算法.doc_第1页
实验报告六--磁盘调度算法.doc_第2页
实验报告六--磁盘调度算法.doc_第3页
实验报告六--磁盘调度算法.doc_第4页
实验报告六--磁盘调度算法.doc_第5页
资源描述:

《实验报告六--磁盘调度算法.doc》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、实验报告六磁盘调度算法班级:软技2班学号:4姓名:刘道林一.实验内容:熟悉磁盘的结构以及磁盘的驱动调度算法的模拟,编程实现简单常用的磁盘驱动调度算法先来先服务(FIFO)、电梯调度算法、最短寻找时间优先算法、扫描(双向扫描)算法、单向扫描(循环扫描)算法等。编程只需实现两个算法。题目可以选取教材或习题中的相关编程实例。编程语言建议采用c/c++或Java。模拟程序鼓励采用随机数技术、动态空间分配技术,有条件的最好能用图形界面展现甚至用动画模拟。实验性质:验证型。二.实验目的和要求1)掌握使用一门语言进行磁盘驱动调度算法的模拟;2)编写程序将磁盘驱动调度算法的过程和结果能

2、以较简明直观的方式展现出来。三.实验原理、方法和步骤1.实验原理磁盘驱动调度对磁盘的效率有重要影响。磁盘驱动调度算法的好坏直接影响辅助存储器的效率,从而影响计算机系统的整体效率。常用的磁盘驱动调度算法有:最简单的磁盘驱动调度算法是先入先出(FIFO)法。这种算法的实质是,总是严格按时间顺序对磁盘请求予以处理。算法实现简单、易于理解并且相对公平,不会发生进程饿死现象。但该算法可能会移动的柱面数较多并且会经常更换移动方向,效率有待提高。最短寻找时间优先算法:总是优先处理最靠近的请求。该算法移动的柱面距离较小,但可能会经常改变移动方向,并且可能会发生进程饥饿现象。电梯调度:总

3、是将一个方向上的请求全部处理完后,才改变方向继续处理其他请求。扫描(双向扫描):总是从最外向最里进行扫描,然后在从最里向最外扫描。该算法与电梯调度算法的区别是电梯调度在没有最外或最里的请求时不会移动到最外或最里柱面,二扫描算法总是移到最外、最里柱面。两端的请求有优先服被务的迹象。循环扫描(单向扫描):从最外向最里进行柱面请求处理,到最里柱面后,直接跳到最外柱面然后继续向里进行处理。该算法与扫描算法的区别是,回来过程不处理请求,基于这样的事实,因为里端刚被处理。2.实验方法1)使用流程图描述演示程序的设计思想;2)选取c/c++、Java等计算机语言,编程调试,最终给出运

4、行正确的程序。四.实验结果分析能够将磁盘驱动调度算法在各种情况下都能得出正确的结论。对FIFO、最短寻找时间优先或电梯调度算法能够在多次模拟数据下得出平均移动柱面数,并进行效率比较分析五.源程序代码#include#include#include#includetypedefstruct_proc{charname[32];/*定义进程名称*/intteam;/*定义柱面号*/intci;/*定义磁道面号*/intrec;/*定义记录号*/struct_proc*prior;struct_pro

5、c*next;}PROC;PROC*g_head=NULL,*g_curr=NULL,*local;intrecord=0;intyi=1;voidinit(){PROC*p;/*初始化链表(初始I/O表)*/g_head=(PROC*)malloc(sizeof(PROC));g_head->next=NULL;g_head->prior=NULL;p=(PROC*)malloc(sizeof(PROC));strcpy(p->name,"P1");p->team=100;p->ci=10;p->rec=1;p->next=NULL;p->prior=g_head;g

6、_head->next=p;g_curr=g_head->next;p=(PROC*)malloc(sizeof(PROC));strcpy(p->name,"P2");p->team=30;p->ci=5;p->rec=5;p->next=NULL;p->prior=g_curr;g_curr->next=p;g_curr=p;p=(PROC*)malloc(sizeof(PROC));strcpy(p->name,"P3");p->team=40;p->ci=2;p->rec=4;p->next=NULL;p->prior=g_curr;g_curr->next=p

7、;g_curr=p;p=(PROC*)malloc(sizeof(PROC));strcpy(p->name,"P4");p->team=85;p->ci=7;p->rec=3;p->next=NULL;p->prior=g_curr;g_curr->next=p;g_curr=p;p=(PROC*)malloc(sizeof(PROC));strcpy(p->name,"P5");p->team=60;p->ci=8;p->rec=4;p->next=NULL;p->prior=g_curr;g_curr->next=p;g_curr=

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。