2022年动态高优先权优先 .pdf
《2022年动态高优先权优先 .pdf》由会员分享,可在线阅读,更多相关《2022年动态高优先权优先 .pdf(13页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、操作系统课程实验报告实验名称:动态高优先权优先姓名:学号:地点:指导老师:专业班级:名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 13 页 - - - - - - - - - 一、实验内容:1、 实验内容:2、 模拟实现动态高优先权优先(若数值越大优先权越高,每运行一个时间单位优先权-n,若数值越小优先权越高,没运行一个时间单位优先权+n) ,具体如下:3、 设置作业体:作业名,作业的到达时间,服务时间,初始优先权,作业状态(W等待,R运行 ,F完成),作业间的链接指针
2、4、 作业初始化:由用户输入作业名、服务时间、初始优先权进行初始化,同时,初始化作业的状态为W。5、 显示函数:在作业调度前、调度中和调度后进行显示。6、 排序函数:对就绪状态的作业按照优先权排序。优先权相同时进入等待队列时间早的作业在前。注意考虑到达时间7、 调度函数:每次从等待队列队首调度优先权最高的作业执行,状态变化。并在执行一个时间单位后优先权变化,服务时间变化,状态变化。当服务时间为0 时,状态变为F。8、 删除函数:撤销状态为F的作业。实验要求:9、 测试数据可以随即输入或从文件中读入。10、必须要考虑到作业的到达时间11、最终能够计算每一个作业的周转时间。三、实验代码#inclu
3、de #include struct PCB charp_name20; intp_priority; intp_needTime; intp_runTime; charp_state; struct PCB* next; ; voidHighPriority(); voidRoundRobin(); void Information(); char Choice(); struct PCB* SortList(PCB* HL); int main() 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - -
4、 - - - 第 2 页,共 13 页 - - - - - - - - - Information(); char choice = Choice(); switch(choice) case 1: system(cls); HighPriority(); break; case 2: system(cls); RoundRobin(); break; default: break; system(pause); return 0; char Choice() printf(nn); printf( * n); printf( 进程调度演示 n); printf( * nnn); printf
5、( 1.演示最高优先数优先算法。n); printf( 2.演示轮转法算法。 n); printf( 3.退出程序。 nnnn); printf( 选择进程调度方法 :); charch = getchar(); returnch; system(cls); voidHighPriority() struct PCB *processes, *pt; /pt 作为临时节点来创建链表processes = pt = (struct PCB*)malloc(sizeof(struct PCB); for (inti = 0; i != 5; +i) struct PCB *p = (struct
6、PCB*)malloc(sizeof(struct PCB); printf( 进程号 No.%d:n, i); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 13 页 - - - - - - - - - printf( 输入进程名: ); scanf(%s, p-p_name); printf( 输入进程优先数: ); scanf(%d, &p-p_priority); printf( 输入进程运行时间: ); scanf(%d, &p-p_needTime); p-
7、p_runTime = 0; p-p_state = W; p-next = NULL; pt-next = p; pt = p; printf(nn); getchar(); /接受回车/processes作为头结点来存储链表processes = processes-next; int cases = 0; struct PCB *psorted = processes; while (1) +cases; pt = processes; /对链表按照优先数排序/psorted用来存放排序后的链表psorted = SortList(psorted); printf(The execute
8、 number: %dnn, cases); printf(* 当前正在运行的进程是:%sn, psorted-p_name); psorted-p_state = R; printf(qname state super ndtime runtimen); printf(%st%ct%dt%dt%dtnn, psorted-p_name, psorted-p_state, psorted-p_priority, psorted-p_needTime, psorted-p_runTime); pt-p_state = W; psorted-p_runTime+; psorted-p_priori
9、ty-; printf(* 当前就绪状态的队列为:nn); /pt 指向已经排序的队列pt = psorted-next; while (pt != NULL) printf(qname state super ndtime runtimen); printf(%st%ct%dt%dt%dtnn, pt-p_name, pt-p_state, pt-p_priority, pt-p_needTime, pt-p_runTime); pt = pt-next; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - -
10、- - - - - 第 4 页,共 13 页 - - - - - - - - - /pt 指向已经排序的链表,判断链表是否有已用时间啊等于需要时间的pt = psorted; struct PCB *ap; ap = NULL; /ap 指向 pt 的前一个节点while (pt != NULL) if (pt-p_needTime = pt-p_runTime) if (ap = NULL) pt = psorted-next; psorted = pt; else ap-next = pt-next; ap = pt; pt = pt-next; if (psorted-next = NU
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年动态高优先权优先 2022 动态 优先权 优先
限制150内