进程调度算法磁盘调度算法银行家算法操作系统课程设.docx
《进程调度算法磁盘调度算法银行家算法操作系统课程设.docx》由会员分享,可在线阅读,更多相关《进程调度算法磁盘调度算法银行家算法操作系统课程设.docx(46页珍藏版)》请在三一办公上搜索。
1、操作系统课程设计说明书学院名称: 专业班级: 姓 名: 学 号: 2013年1月1日评分标准优秀:有完整的符合标准的文档,文档有条理、文笔通顺,格式正确,程序完全实现设计要求,独立完成;良好:有完整的符合标准的文档,文档有条理、文笔通顺,格式正确;程序完全实现设计要求,独立完成,但存在少量错误;中等:有完整的符合标准的文档,有基本实现设计方案的软件,设计方案正确;及格:有完整的符合标准的文档,有基本实现设计方案的软件,设计方案基本正确;不及格:没有完整的符合标准的文档,软件没有基本实现设计方案,设计方案不正确。没有独立完成,抄袭或雷同。成绩评定为: 。 指导教师: 年 月 日目 录 一进程调度
2、算法 4-23 页二银行家算法 24-34 页三磁盘调度算法 35-46页进程调度算法1设计目的 在多道程序设计中,经常是若干个进程同时处于就绪状态,必须依照某种策略决定哪个进程优先占有处理机,因而必须解决进程调度的问题,进程调度算法就是要解决进程调度的问题。2. 任务及要求2.1 设计任务 设计程序来模拟进程的四种调度算法,模拟实现调度的基本功能。2.2 设计要求 产生的各种随机数要加以限制,如alltime限制在40以内的整数。进程的数量n不能取值过大。3. 算法及数据结构3.1算法的总体思想(流程) 每个用来标识进程的进程控制块PCB用结构来描述,包括以下字段:(1)进程优先数ID,其中
3、0为闲逛进程,用户进程的标识数为1,2,3。(2)进程优先级Priority,闲逛进程(idle)的优先级为0,用户进程的优先级大于0,且随机产生,优先数越大,优先级越高。(3)进程占用的CPU时间CPUtime,进程每运行一次,累计值等于4。(4)进程总共需要运行时间Alltime,利用随机函数产生。(5)进程状态,0:就绪态;1:运行态;2:阻塞态。 利用链表将数据连接起来,实现数据的存储。3.2 链表模块3.2.1 功能 实现链表的存储功能,以及实现存储的查找功能。3.2.2 数据结构 构造链表这个数据结构,以及链表的初始化,链表的插入,链表的长度。3.2.3 算法 typedef st
4、ruct ElemType *elem; int length; int listsize; SqList;Status InitList(SqList &l)l.elem=(ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType);if(!l.elem) exit(OVERFLOW);l.length=0;l.listsize=LIST_INIT_SIZE;return OK;int ListLength(SqList l)return(l.length);Status ListInsert_Sq(SqList &L,int i, ElemType e
5、)/在顺序表L的第i个位置前插入元素e,i的合法值为1.L.length+1 if(iL.length+1) return ERROR; if(L.length=L.listsize) ElemType*newbase=(ElemType *)realloc(L.elem,(L.listsize+LISTINCREMENT)*sizeof(ElemType); if(!newbase) exit(OVERFLOW); L.elem=newbase; L.listsize+=LISTINCREMENT; ElemType *q=&L.elemi-1, *p=&L.elemL.length-1;
6、while(p=q) *(p+1)=*p; -p; /插入位置后的元素右移 *q=e; +L.length; return OK;Status GetElem(SqList L,int i,ElemType &e)if(iL.length)return ERROR;elsee=*(L.elem+i-1);return OK;void Outputlist(SqList &L)if(0=L.length)printf(空集!);else for(int i=0;iL.length;+i) printf(%c,*(L.elem+i);3.3 主函数模块3.3.1功能 实现进程调度的四种算法,以及人
7、机交互的菜单。3.3.2 数据结构 主要包括五个部分,分别是四种算法,和进程的输入和菜单部分,功能分别实现。3.3.3算法void main()for(1;)int number; PCB pcb100 ;srand(time(0);int max;int ppp100;int time=0;int time1;int m;int a100;a0=0;printf(n*进程调度算法的模拟*n);printf(* 1.先到先服务调度 2.最短作业优先调度 *n);printf(* 3.优先权调度 4.轮转发调度 *n);printf(*);printf(n请选择调度的方法: );scanf(%d
8、,&m);if(m!=1&m!=2&m!=3&m!=4) printf(输入错误! 重新输入: ); scanf(%d,&m); if(m!=1&m!=2&m!=3&m!=4) printf(输入错误! 重新输入: ); scanf(%d,&m); if(m!=1&m!=2&m!=3&m!=4) printf(输入错误! 重新输入: ); scanf(%d,&m); if(m!=1&m!=2&m!=3&m!=4) printf(输入错误! 重新输入: ); scanf(%d,&m); printf(请输入进程的个数: );scanf(%d,&number);printf(n开始时用户进程均为就
9、绪状态,运行时间随机产生nn);SqList sq;InitList(sq);for(int r=0;rnumber;r+)pcbr.CPUtime=0;for(int i=0;inumber;i+) pcbi.Priority=rand()%50;while(1) if(pcbi.Priority20) pcbi.Priority=rand()%50; else break; pcbi.Alltime=rand()%40;while(1) if(pcbi.Alltime10) pcbi.Alltime=rand()%40;else break;for(int j=0;jnumber;j+)L
10、istLength(sq);ListInsert_Sq(sq,ListLength(sq),pcbi ); if(m=1) printf(n*程序演示开始*n); int coun=0; /计数变量 int wait100; /等待时间数组 wait0=0; int Allwait=0; for(int i1=0;i1number;i1+)printf(下面开始调用第%d个进程; n,i1); printf(开始时间为%d 执行时间为%dn,coun,pcbi1.Alltime); coun+=pcbi1.Alltime; if(i1!=0)waiti1=pcbi1-1.Alltime+wai
11、ti1-1; for(int i2=0;i2number;i2+)Allwait=waiti2+Allwait; printf(平均等待时间为:%dn,Allwait/number); if(m=2) int min=pcb0.Alltime; int wait1100; wait10=0; int in=0; int coun1=0; printf(*最短作业优先调度!*n); cout进程所需时间分别是:endl; for(i=0;inumber;i+) coutpcbi.Alltimeendl; printf(进程调度的顺序为: ); for(i=0;inumber;i+) min=50
12、; for(j=0;jnumber;j+) if(pcbj.Alltimemin) min=pcbj.Alltime; in=j; printf(%d ,in+1); pcbin.Alltime+=50; if(m=3) printf(ID 优先级 运行总时间 进程状态n); for(int k=0; knumber; k+) printf(%d %d %d 就绪n,k+1, pcbk.Priority, pcbk.Alltime); printf(n*程序调度演示开始*n); for(int f=1;f1000;f+) int count=0,count1=0; for(int i=0;in
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 进程 调度 算法 磁盘 银行家 操作系统 课程
链接地址:https://www.31ppt.com/p-1658485.html