已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include#include#include #include#define N 20#define MAX 100typedef struct PCB /pcb进程控制块定义 int numN; /进程序号 char name10; /进程名 char state; /进程状态 int tijiaotime; /进程到达时间 int runtime; /进程开始时间 int finishtime; /进程结束时间 int needtime; /服务时间 int pro;/进程优先级 struct PCB *next; /链接指针 指向下个作业的pcb;struct PCB *head_input;struct PCB *head_run;struct PCB *head_run_pre;unsigned long current; /记录系统当前时间的变量int time=10000,n; /计时器 pcb *head=NULL,*p,*q;void getInfo() /创建进程 int num; printf(n请输入要建立的进程个数:); scanf(%d,&n); for(num=0;numnum,&p-name,&p-tijiaotime,&p-needtime); if(p-tijiaotime tijiaotime; q-next=p; p-runtime=0; p-finishtime=0; p-next=NULL; p-state=W; q=p; / *1.先来先服务调度算法*void run_fcfo(pcb *p1)/定义先来先到服务的算法 time = p1-tijiaotime time? p1-tijiaotime:time; p1-runtime=time; printf(n现在时间是%d,开始运行进程%sn,time,p1-name); time+=p1-needtime; p1-state=F; p1-finishtime=time; printf(进程名 开始时间 所需时间 结束时间n); printf(%s %d %d %d ,p1-name,p1-runtime,p1-needtime,p1-finishtime);void fcfo()/定义运行进程函数 int i,j,t; for(j=0;jn;j+) p=head; t=10000; for(i=0;itijiaotimestate=W) t=p-tijiaotime; q=p; /标记当前未完成的进程 p=p-next; run_fcfo(q); / *2.优先级调度服务算法*int readydata() /建立就绪队列 if(head_input-next=NULL) return 0; struct PCB *p1=head_input-next,*pmax,*p2; int maxpro=0xffff; pmax=p1; p2=head_input; while(p1!=NULL) if(p1-propro; head_run_pre=p2;pmax=p1; p2=p1; p1=p1-next; head_run=pmax; head_run_pre-next=head_run-next; return 1;void runprocess() /运行进程函数 head_run-runtime-=10; head_run-pro+; struct PCB *p1,*p2; printf(时间片的大小 %d,current); current+=10; printf( %s 开始n,head_run-name); printf(时间片的大小 %d,current); printf( %s 结束n,head_run-name); if(head_run-runtimenext; p1-next=head_run; head_run-next=p2; int readyprocess() while(1) if(readydata()=0) return 0; else runprocess(); void Init() head_input=new PCB; head_input-next=NULL; current=0; int numpro; printf(请重新输入要建立的进程个数:); scanf(%d,&numpro); printf(请依次输入 进程名 运行时间 优先级n); for(int i=0;iname); scanf(%d,&p1-runtime); scanf(%d,&p1-pro); p1-state=C; p1-next=NULL; struct PCB *p2=head_input-next; head_input-next=p1; p1-next=p2; / *3.时间片轮转调度服务算法*void shijianpian()int b,i,X,t,k;int aMAX;/存放进程的剩余时间int cntMAX;/存放进程调度次数printf(请输入进程数:);scanf(%d,&X);printf(n请输入时间片t大小:);scanf(%d,&t);printf(n请依次输入各个进程的服务时间);for(i=0;iX;i+)scanf(%d,&ai);cnti=0;printf(被调度进程t进程调度次数 t本次运行时间结果t剩余时间n);k=1;while(k)for(i=0;i=t) ai-=t; b+=t; cnti=cnti+1; printf(nt%dtt%dtt%dtt%d,i+1,cnti,b,ai); else b=b+ai; cnti=cnti+1; ai=0; printf(nt%dtt%dtt%dtt%d,i+1,cnti,b,ai);else continue;for(i=0;i=X) k=0;void main() printf( *); printf(n 1. 按先来先到服务调度的算法模拟n); printf( *); getInfo(); fcfo(); printf(n *); printf(n 2
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 齐齐哈尔市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解(a卷)
- 2026年省属虚拟市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(新)
- 石柱县农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)附答案详解(考试直接用)
- 延边朝鲜族自治州农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(真题汇编)
- 淮南市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解(预热题)
- 2025年广东省惠州市辅警考试公安基础知识考试真题库及参考答案
- 铜仁地区农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)带答案详解(完整版)
- 2025年广东省东莞市辅警考试公安基础知识考试真题库及参考答案
- 昌都地区农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(易错题)
- 葫芦岛市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解(培优b卷)
- 红梅杏种植科技化示范园区建设可研报告
- 安宁疗护营养管理
- 《双碳管理基础与实务》课件-第一章- 概述
- 隐形眼镜医疗器械质量管理制度
- 离婚协议书自取(2025年版)
- 执业兽医资格考试速记小册
- 集团化办学的组织架构与管理模式
- 肾功能衰竭患者的运动康复及注意事项
- 老舍《茶馆》三幕话剧剧本
- 高考数学函数专题知识训练50题(含参考答案)-5份
- T-ZSA 288-2024 餐饮设备智能烹饪机器人系统通.用技术要求
评论
0/150
提交评论