操作系统实验报告时间片调度轮转算法.docxVIP

操作系统实验报告时间片调度轮转算法.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统实验报告第一次实验——时间片调度轮转算法实验时间:2014.11.7院系:计算机科学与技术学院班级:软件2班实验要求:实验选题:时间片调度轮转算法程序流程图及程序代码流程图确定时间片大小就绪队列为空空则等待进行下一否选择队首进程进行执行一个时间片次执行该进程运行完成否送到就绪队列末尾是程序代码:#includestdio.h#includeconio.h#define N 20typedef struct pcb{char pname[N];int runtime;int arrivetime;char state;struct pcb*next;}PCB;PCB head_input;PCB head_run;PCB * pcb_input;static char R=r,C=c;unsigned long current;void inputprocess();int readyprocess();int readydata();int runprocess();FILE *f;int readyprocess(){while(1){if(readydata()==0)return 1;else runprocess();}}int readydata(){if(head_input.next==NULL){if(head_run.next==NULL)return 0;else return 1;}PCB *p1,*p2,*p3;p1=head_run.next;p2=head_run;while(p1!=NULL){p2=p1;p1=p2-next;}p1=p2;p3=head_input.next;p2=head_input;while(p3!=NULL){if(((unsigned long)p3-arrivetime=current)(p3-state==R)){printf(时间片为 %8d(时间 %4d);进程 %s 开始,\n,current,(current+500)/1000,p3-pname);fprintf(f,时间片为 %8d(时间 %4d);进程 %s 开始,\n,current,(current+500)/1000,p3-pname);p2-next=p3-next;p3-next=p1-next;p1-next=p3;p3=p2;}p3=p3;p3=p3-next;}return 1;}int runprocess(){PCB *p1,*p2;if(head_run.next==NULL){current++;return 1;}else {p1=head_run.next;p2=head_run;while(p1!=NULL){p1-runtime--;current++;if(p1-runtime=0){printf(时间片为 %8d 时间 %4d 进程 %s 结束.\n,current,(current+500)/1000,p1-pname);fprintf(f,时间片为 %8d 时间 %4d 进程 %s 结束.\n,current,(current+500)/1000,p1-pname);p1-state=C;p2-next=p1-next;delete p1;p1=NULL;}else{p2=p1;p1=p2-next;}}return 1;}}void inputprocess(){PCB *p1,*p2;int num;unsigned long max=0;printf(请输入进程的数量:);fprintf(f,请输入进程的数量:);scanf(%d,num);fprintf(f,%d\n,num);p1=head_input;p2=p1;p1-next=new PCB;p1=p1-next;for(int i=0;inum;i++){printf(请输入第%d个进程的进程名:,i+1);fprintf(f,请输入第%d个进程的进程名:,i+1);scanf(%s,p1-pname);fprintf(f,%s\n,p1-pname);printf(它的运行时间为:);fprintf(f,它的运行时间为:);scanf(%d,(p1-runtime));fprintf(f,%d\n,(p1-runtime));printf(它的到达时间为:);fprintf(f,它的到达时间为:);scanf(%d,(p1-arrivetime));fprintf(f,%d\n,(p1-arrivetime));p1-runtime=(p1-runtime)*1000;p1-arrivetime=(p1-arrivetime)*1000;p1-state=R;if((unsigned

文档评论(0)

haihang2017 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档