操作系统实验一.docx
《操作系统实验一.docx》由会员分享,可在线阅读,更多相关《操作系统实验一.docx(10页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精品文档,仅供学习与交流,如有侵权请联系网站删除学号E11614051 专业计算机科学与技术 姓名施飞宇实验日期2018/10/25 教师签字 成绩实验报告【实验名称】 进程调度【实验目的】巩固和加深处理机调度的概念。设计调度算法,模拟实现处理机的调度【实验原理】先来先服务(FCFS)调度算法FCFS是最简单的调度算法,该算法既可用于作业调度,也可用于进程调度。 当在作业调度中采用该算法时,系统将按照作业到达的先后次序来进行调度,或者说它是优先考虑在系统中等待时间最长的作业,而不管该作业所需执行时间的长短,从后备作业队列中选择几个最先进入该队列的作业,将它们调入内存,为它们分配资源和创建进程,
2、然后把它放入就绪队列。【实验内容】本次实验进程的数据结构如下:typedef struct pcbchar pnameN;/进程名int runtime;/运行时间int arrivetime;/到达时间int starttime;/开始运行时间 float avgtime;/带权周转时间char state;/进程状态 struct pcb *next;/链表指针PCB;1. 设计先来先服务调度算法FCFS测试数据:算法流程图(图1):图1源代码:/*2018/10/26 施飞宇 笃行南楼a202*/#define N 20#include #include using namespace
3、std;typedef struct pcbchar pnameN;/进程名int runtime;/运行时间int arrivetime;/到达时间int starttime;/开始运行时间 float avgtime;/带权周转时间char state;/进程状态 struct pcb *next;/链表指针PCB;PCB headinput;PCB headrun;PCB * pcbinput;void inputprocess();/建立进程函数int readydata()return 1;/判断进程是否进入就绪函数void runprocess();/运行进程函数void inpu
4、tprocess()PCB *p1,*p2;cout输入进程数目num;int i=0;p1=&headinput;p2=p1;for(i=0;inum;i+)cout输入第i+1进程名,运行时间,到达时间pname);cinp1-runtime;cinp1-arrivetime;p1-next=new PCB;p2=p1;p1=p1-next;delete p1;p1=NULL;p2-next=NULL;void runprocess()PCB *p1;int time=0;/时间p1=&headinput;printf(进程名到达时间服务时间开始执行时间完成时间周转时间带权周转时间n);w
5、hile(p1!=NULL)if(timestarttime)time=p1-starttime;p1-starttime=time; p1-avgtime=(p1-starttime+p1-runtime-p1-arrivetime)*1.0/p1-runtime;time=p1-starttime+p1-runtime; printf(%s %10d %10d %10d %10d %10d %5fn,p1-pname,p1-arrivetime,p1-runtime,p1-starttime,p1-starttime+p1-runtime,p1-starttime+p1-runtime-p
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 实验
限制150内