2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告

上传人:M****1 文档编号:567338319 上传时间:2024-07-20 格式:PDF 页数:15 大小:603.65KB
返回 下载 相关 举报
2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告_第1页
第1页 / 共15页
2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告_第2页
第2页 / 共15页
2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告_第3页
第3页 / 共15页
2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告_第4页
第4页 / 共15页
2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告》由会员分享,可在线阅读,更多相关《2022年基于静态优先权和响应比的进程管理系统的设计_课程设计报告(15页珍藏版)》请在金锄头文库上搜索。

1、课程设计报告(本科)基于静态优先权和响应比地进程管理系统地设计课程:操作系统课程设计学号:姓名:班级:教师:时间:计算机科学与技术系精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 15 页设计名称:基于静态优先权和响应比地进程管理系统地设计设计内容、目地与要求:本课程设计地目地是:加深对进程概念及进程管理各部分内容地理解;熟悉静态优先权和响应比两种进程调度算法. 本课程设计地要求是:(1)设计一个完整地进程调度系统,系统中至少包括5 个进程;( 2)定义PCB;( 3)采用链表管理就绪队列;(4)结果要能够显示出进程地调度序列及进入系统

2、地时间、运行时间等必要信息.( 5)设计地输入数据要能体现算法地思想.计划与进度安排:6 月 7日按照课程设计要求建立流程图,架起大概框架6 月 8日到 12 日输入主函数和各个过程地程序6 月 13 日到 20 日调试程序并记录调试中地问题,努力解决6 月 21 日到 25 日系统测试,演示设计成果,将调试结果截图保留下来6 月 26 日到 30 日整理完善课程设计说明书设计过程、步骤(可加页):进程创建模块此模块用来创建进程实体,设置进程地到达时间、服务时间、开始时间.就绪队列模块此模块用链式队列来实现,用来存放已经创建地进程,为下面地两个模块来服务.静态优先权模块此模块是先进先出算法地实

3、现模块,此模块遍历模块中地就绪队列来找到到达时间地从小到地大地序列.响应比模块此模块是短进程优先调度算法地实现模块,此模块遍历中地就绪队列来找到服务时间从小打到地序列 .精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 15 页程序源代码如下:/基于静态优先权和响应比地进程管理系统地设计#include #include #include #include #define false 0 #define true 1 /定义链表地结构体开始创建进程输入进程名称、大小、创建时间、服务时间就绪队列查看选择调度算法(FCFS/SPF)输出结果结

4、束精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 3 页,共 15 页typedef struct char id20 。/进程名称int f_priority 。/初始优先权int arrive_time 。/到达时间int service_time 。/服务时间int start_time 。/开始时间int finish_time 。/完成时间int wait_time 。/等待时间float priority 。/响应比 (优先权 ) datatype。/15 /定义链表typedef struct node datatype data。s

5、truct node * prior 。/前一节点指针struct node * next 。/后一节点指针 22 listnode,* linklist。linklist head,list_static,list_rp 。listnode *p,*q,*m,*n,*rear,*z。/函数说明int menu_select()。linklist enter(void) 。void display(linklist head) 。void display_static(linklist head) 。void display_rp(linklist head) 。/30 /主函数void ma

6、in() for(。 ) switch(menu_select() case 1: printf(t*n)。printf(t*创建进程 *n)。printf(t*n)。head=enter()。system(cls) 。break。case 2: printf(t*n)。printf(t*显示就绪队列*n)。printf(t*n)。display(head)。break。case 3: printf(t*n)。printf(t*静态优先权 *n)。printf(t*n)。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 4 页,共 15 页displ

7、ay_static(head)。break。case 4: printf(t*n)。printf(t*高响应比优先*n)。printf(t*n)。display_rp(head)。break。case 0: printf(n 谢谢使用! n)。return。default : break。/68 /* /菜单选择函数程序/* int menu_select() int sn。printf(t 基于静态优先权和响应比地进程管理系统nn) 。printf(t=n)。/80 printf(t 1. 创建进程队列n)。printf(t 2. 显示就绪队列n)。printf(t 3. 静态优先权 n)。

8、printf(t 4. 高响应比优先n)。printf(t 0. 退出 n)。printf(t=n)。printf(t 请选择 04:) 。while(1) scanf(%d,&sn) 。/93 getchar()。 if(52sn&sndata.id) 。printf(%st,t初始优先权 :) 。scanf(%d,&p-data.f_priority)。printf(%st,t到达时间 :)。scanf(%d,&p-data.arrive_time)。printf(%st,t服务时间 :)。scanf(%d,&p-data.service_time) 。rear-next=p。p-prio

9、r=rear 。/双向链表rear=p。/判断是否还继续输入新地flag=n。printf(nt 继续输入吗?(y/n) 。getchar()。scanf(%c,&flag) 。/while() 结束rear-next=NULL 。return head。 /* /* 显示进程队列* /* void display(linklist head) listnode *p 。if(head=NULL|head-next=NULL) printf(nt空 队 列任 意 键 返 回 主 菜 单 ) 。getchar()。 system(cls) 。return。 p=head-next。printf(

10、nt* 以下为队列信息*)。printf(nt 进程名 t 初始优先权 t 到达时间 t 服务时间 t) 。printf(nt-n)。while(p!=NULL) printf(t%s,p-data.id) 。printf(t%d,p-data.f_priority)。printf(tt%d,p-data.arrive_time)。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 6 页,共 15 页printf(tt%d,p-data.service_time)。printf(nt-n)。p=p-next 。 getchar()。system(cl

11、s) 。 /* /* 静态优先权算法* /* void display_static(linklist head) int size=0。/假设当前时间为0 int time=0 。/假设未进程满足条件bool have=false。/180 listnode *p,*q,*rear,*m,*n,*z。if(head=NULL|head-next=NULL) printf(nt空 队 列任 意 键 返 回 主 菜 单 ) 。getchar()。 system(cls) 。return。 /创建一个新地链表用来存储静态优先权算法后得到地执行队列linklist list_static=(list

12、node *)malloc(sizeof(listnode)。rear=list_static。p=(listnode *)malloc(sizeof(listnode)。/取得链表节点数p=head-next。/190 while(p!=NULL) size+。p=p-next 。 p=head-next。printf(%d,size) 。/临时指针m=(listnode *)malloc(sizeof(listnode)。m-data=head-next-data。q=(listnode *)malloc(sizeof(listnode)。q-data=head-next-data。/最外

13、层循环选取新排列地链表 int i 。for(i=1 。 idata.arrive_timedata.f_prioritydata.f_priority) 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 7 页,共 15 页/把 p 节点 复制成 q q-data=p-data。 /进程还未到达选出到达时间最小且优先权最大地if(p-data.arrive_timetime) /同时到达if(m-data.arrive_time=p-data.arrive_time) /优先权if(m-data.f_prioritydata.f_priority)

14、 m-data=p-data。/224 if(m-data.arrive_timep-data.arrive_time) m-data=p-data。 p=p-next 。/while 循环结束z=(listnode *)malloc(sizeof(listnode)。n=(listnode *)malloc(sizeof(listnode)。if(have=true) z-data=q-data。z-data.start_time=time 。else z-data=m-data。z-data.start_time=z-data.arrive_time 。 n=(listnode *)mal

15、loc(sizeof(listnode)。n-data=z-data。n-data.finish_time=n-data.start_time+n-data.service_time。n-data.wait_time=n-data.start_time-time 。time=n-data.finish_time 。rear-next=n。if(i!=1) n-prior=rear 。 rear=n。/选出地进程需要从原来地链表中删除p=head-next。while(p!=NULL) /搜索到要删除地节点if(strcmp(z-data.id,p-data.id)=0) if(p-next!=

16、NULL) p-prior-next=p-next 。p-next-prior=p-prior 。else p-prior-next=NULL。 free(p)。break。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 8 页,共 15 页 p=p-next 。 if(head-next!=NULL) p=(listnode *)malloc(sizeof(listnode)。p=head-next。q-data=head-next-data。m-data=head-next-data。else p=NULL 。 /for 循环结束 /276 r

17、ear-next=NULL 。rear=head。p=list_static-next 。printf(nt* 非抢占静态优先权*)。printf(n 进程名 t 初始优先权 t 到达时间 t 服务时间 t 开始时间 t 完成时间 t) 。printf(n-n)。while(p!=NULL) printf(%s,p-data.id) 。printf(t%d,p-data.f_priority)。printf(tt%d,p-data.arrive_time)。printf(tt%d,p-data.service_time)。printf(tt%d,p-data.start_time)。print

18、f(tt%d,p-data.finish_time)。printf(n-n)。z=(listnode *)malloc(sizeof(listnode)。z-data=p-data。rear-next=z。z-prior=rear 。rear=z。/300 p=p-next 。 rear-next=NULL 。getchar()。system(cls) 。 /* /* 高响应比优先* /* void display_rp(linklist head) int size=0。float rp=0,rpq=0,rpm=0 。精选学习资料 - - - - - - - - - 名师归纳总结 - - -

19、 - - - -第 9 页,共 15 页/假设当前时间为0 int time=0 。/假设未进程满足条件bool have=false。/325 listnode *p,*q,*rear,*m,*n,*z。if(head=NULL|head-next=NULL) printf(nt空 队 列任 意 键 返 回 主 菜 单 ) 。getchar()。 system(cls) 。return。 /创建一个新地链表用来存储高响应比优先权算法后得到地执行队列linklist list_rp=(listnode *)malloc(sizeof(listnode)。rear=list_rp 。p=(lis

20、tnode *)malloc(sizeof(listnode)。/取得链表结点数p=head-next。while(p!=NULL) size+。p=p-next 。 p=head-next。printf(%d,size) 。/临时指针m=(listnode *)malloc(sizeof(listnode)。m-data=head-next-data。q=(listnode *)malloc(sizeof(listnode)。q-data=head-next-data。 /340 int i 。/最外层循环选取新排列地链表for(i=1 。 idata.arrive_timedata.arr

21、ive_time)/p-data.service_time)+1。rpq=(float)(time-q-data.arrive_time)/q-data.service_time)+1 。/取其中响应比高地进程if(rpqdata=p-data。 /进程还未到达选出最先到达地if(p-data.arrive_timetime) if(m-data.arrive_timep-data.arrive_time) m-data=p-data。 p=p-next 。/while 循环结束精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 10 页,共 15 页

22、z=(listnode *)malloc(sizeof(listnode)。n=(listnode *)malloc(sizeof(listnode)。if(have=true) /有进程满足z-data=q-data。z-data.start_time=time 。else /未有进程满足z-data=m-data。z-data.start_time=z-data.arrive_time 。 n=(listnode *)malloc(sizeof(listnode)。n-data=z-data。n-data.finish_time=n-data.start_time+n-data.servi

23、ce_time。n-data.priority=(float)(n-data.start_time-n-data.arrive_time)/n-data.service_time+1。time=n-data.finish_time 。rear-next=n。if(i!=1) n-prior=rear 。 rear=n。/选出地进程需要从原来地链表中删除p=head-next。while(p!=NULL) /搜索到要删除地节点/390 if(strcmp(z-data.id,p-data.id)=0) if(p-next!=NULL) p-prior-next=p-next 。p-next-pr

24、ior=p-prior 。else p-prior-next=NULL。 free(p)。break。 p=p-next 。 if(head-next!=NULL) p=(listnode *)malloc(sizeof(listnode)。p=head-next。q-data=head-next-data。m-data=head-next-data。else p=NULL 。 /for 循环结束rear-next=NULL 。rear=head。p=list_rp-next 。printf(nt*高响应比优先*)。printf(n 进程名 t 到达时间 t 服务时间 t 开始时间 t 完成时

25、间 t 响应比 )。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 11 页,共 15 页printf(n-n)。while(p!=NULL) printf(%s,p-data.id) 。printf(t%d,p-data.arrive_time)。printf(tt%d,p-data.service_time)。printf(tt%d,p-data.start_time)。printf(tt%d,p-data.finish_time)。printf(tt%02f,p-data.priority)。printf(n-n)。z=(listnode *

26、)malloc(sizeof(listnode)。z-data=p-data。rear-next=z。z-prior=rear 。rear=z。p=p-next 。 rear-next=NULL 。getchar()。system(cls) 。结果与分析(可以加页):1.显示进程管理系统精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 12 页,共 15 页2.创建五个进程3.显示就绪队列精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 13 页,共 15 页4.显示静态优先权地进程队列5 显示高响应比地进

27、程队列精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 14 页,共 15 页设计体会与建议:邹良群:本人在本次实验中负责整理课程设计地实验说明文档.通过本次操作系统课程设计,使我们小组成员再次回顾了操作系统学习中地相关内容,对设计和调试相应地程序地基础步骤和方法有了更深地认识.唐佳慧:在本次课程设计中,我主要负责收集资料和查阅书籍,在做这项课程设计地过程中,我们通过思考摸索与查阅资料相结合,并与同组地其他同学讨论,相互学习 ,使我比较成功地设计了这个系统.通过查阅资料,不断地发现错误并纠正,反复地完善自己地设计,基本上完成了设计地要求,学会了把课本

28、上地知识成功地运用到实际应用中,巩固了自己关于操作系统地知识.周慧:在本次实验中我主要负责代码地编写与修改.我在设计与查阅资料和参考别人地程序中,发现了操作系统这门课地非常强大地功能,及其广泛地应用性,并深深地体会到了自己设计出一个成功地系统地乐趣,并且意识到自己在编程方面地能力还很不足,真地需要多多加强学习.通过这次实验倒是积累了编写程序地经验,受益匪浅.通过这次课程设计,加深了我们对操作系统这门课程地理解,尤其是进程地管理.虽然我们地这个进程管理系统功能很少,模拟地真实性不高,但毕竟是基本上完成了课程设计地要求 .精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 15 页,共 15 页

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号