- 1、本文档共36页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《高级程序设计语言》课程设计报告
题目: 处理机低级调度模拟系统
专业:
班级:
学号:
姓名:
指导教师:
完成日期:2013年2月25 日
一、课程设计目的
1、掌握C语言数组、函数、指针、结构体的综合应用。
2、掌握使用C语言,进行应用性的开发。
3、掌握系统数据结构与算法的设计。
二、课程设计内容
课程设计题目:处理机低级调度模拟系统
课程设计内容:根据操作系统处理机不同的调度算法,使用C 语言
模拟实现处理机调度过程。
1、系统数据结构
(1)进程控制块(pcb):进程名称、到达时间、进程要求运行时
间、进程已运行时间、指针、进程状态等等(要根据不同算法的需要
定义全面的数据结构)
(2)进程队列(PQueue):链表……
2、调度算法
(1)先来先服务调度(FCFS):按照进程提交给系统的先后顺序
来挑选进程,先提交的先被挑选。
(2)短进程优先调度(SJF):是以进入系统的进程所提出的“执
行时间”为标准,总是优先选取执行时间最短的进程。
(3)高响应比优先调度(HRN):是在每次调度前都要计算所有
被选进程 (在后备队列中)的响应比,然后选择响应比最高的进程执
行。
i-1
(4)多级反馈队列调度(FB,第i级队列的时间片=2 ):(a)应
设置多个就绪队列,并为各个队列赋予不同的优先级。(b)当一个
新进程进入内存后,首先将它放入第一队列的末尾,按FCFS 的原则
排队等待调度。当轮到该进程执行时,如他能在该时间片内完成,便
可准备撤离系统;如果它在一个时间片结束时尚未完成,调度程序便
将该进程转入第二队列的末尾,再同样地按FCFS原则等待调度执行;
如果它在第二队列中运行一个时间片后仍未完成,再依次将它放入第
三队 ……,如此下去,当一个长作业进程从第一队列依次降到第N
队列后,在第N队列中便采取时间片轮转的方式运行。(c)仅当第
一队列空闲时,调度程序才调度第二队列中的进程运行。
三、课程设计的要求
1、按照给出的题目内容
(1)完成系统数据结构设计与实现、系统算法设计与实现、系统模
块设计与实现、系统总体的设计与实现。
(2)系统需要一个简单操作界面,例如:
===========================
1. 先来先服务调度
2. 短进程优先调度
3. 高响应比优先调度
4. 多级反馈队列调度
5. 退出
(按数字1、2、3、4、5,选择操作)
===========================
(3)对每种调度算法都要求输出每个进程(进程数不少于5)开
运行时刻、完成时刻、周转时间,以及这组进程的平均周转时间。
(4)画出每种调度算法流程图。
2、写出课程设计报告,设计报告提交形式:电子文档提交
3、个人独立完成。
4、完成时间(1 周)
四、课程设计过程
1、系统中所使用的数据结构及说明
//数据结构的定义
//定义进程控制块PCB
typedef struct PCB
{
char PID[5]; //进程标示符
char Name[10]; //进程名称
int PRI; //进程的优先级(越小越高)
float NeedTime; //进程要求运行时间(服务时间)
float StartTime; //进程进入就绪队列的时间(到达时间)
float RunBeginTime; //开始运行时间
float UpTime; //进程已运行时间
float OverTime; //进程运行完成的时间
float TurnaroundTime; //周转时间
文档评论(0)