ImageVerifierCode 换一换
格式:DOCX , 页数:21 ,大小:371.19KB ,
资源ID:10876953      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-10876953.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(操作系统课程设计处理机管理.docx)为本站会员(b****1)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

操作系统课程设计处理机管理.docx

1、操作系统课程设计处理机管理操作系统课程设计题 目:处理机管理 学生:XXX学 院:信息工程学院系 别:计算机系 专 业:软件工程 班 级:软件09-1指导教师:XXX 教授XXX 教授2011年12月30日XXX大学课程设计任务书学院(系):课程名称:操作系统课程设计 指导教师(签名):专业班级: 软件工程 091 学生: XXX 学号: XXXXXXXXX 一、课程设计题目处理机管理二、课程设计的目的学生通过设计一个模拟单处理机调度的算法,以巩固和加深处理机调度的概念。使学生初步具有研究、设计、编制和调试操作系统模块的能力。三、课程设计的主要容和要求(包括原始数据、技术参数、设计要求、工作量

2、要求等) 原始数据:进程控制块PCB结构体。 技术参数:Windows XP系统,VC+6.0开发工具。设计要求:1设计基于时间片轮转法的处理机调度算法;2或设计基于先来先服务或基于优先权的处理机调度算法;3画出以上算法流程图;4编程实现算法功能;5编写课程设计说明书。工作量要求:完成以上设计要求中的所有算法功能。四、工作进度安排周一:布置、讲解题目,收集资料;周二:系统分析,算法设计;周三:编制、调试程序;周四:测试系统,形成设计结论,编写课设报告;周五:系统与材料验收,课设答辩。五、主要参考文献1尧学编计算机操作系统教程(第三版)习题解答与实验指导:清华大学,20062 汤子瀛主编计算机操

3、作系统(第三版):电子科技大学,2001 3坤等编操作系统实验教程:清华大学,2008审核批准意见系(教研室)主任(签字)第一章 系统概述1.1 功能简介处理机调度是操作系统中非常重要的部分。在多道程序设计系统中,存中有多道程序运行,他们相互争夺处理机这一重要的资源。处理机调度就是从就绪队列中,按照一定的算法选择一个进程并将处理机分配给它运行,以实现进程并发地执行。本系统就是设计了一个模拟单处理机调度的算法,以模拟实现处理机调度的基本功能。本系统是采用时间片轮转算法模拟单处理机调度。1.2 设计思路系统将所有的就绪进程按先来先服务的原则排成一个队列,每次调度时,把CPU分配给队首进程,并令其执

4、行一个时间片。时间片的大小由输入确定。当执行的时间片用完时,由一个计时器发出时钟中断请求,调度程序便据此信号来停止该进程的执行,并将它送往就绪队列的末尾;然后,再把处理机分配给就绪队列中的队首进程,同时也让它执行一个时间片。这样就可以保证就绪队列中的所有进程在一给定的时间获得一时间片的处理机执行时间。换言之,系统能在给定的时间响应所有用户的请求。每个进程用一个进程控制块PCB来代表。PCB的格式如图1-1所示。进程名指针到达时间估计运行时间进程状态 图1-1 进程控制块其中,进程名即进程标识。第二章 系统功能分析和设计 在本章中,主要是介绍各个功能函数的设计思路和实现方法。2.1 系统主要结构

5、模块 本系统主要分为:主函数,创建进程队列函数,对进程队列按到达时间进行排序,输出所创建的进程信息,执行时间片调度算法。在程序执行过程过主函数调用各个子函数来一次实现系统的各个功能。系统主要结构模块如图2-1:图2-1 程序结构模块2.2 创建进程队列功能 在此函数中输入所要创建进程的总个数n,然后再通过for循环语句来控制,依次输入各个进程的属性值,再把刚创建的进程加入进程就绪队列的队尾,循环上述操作n次。其中,在创建进程的过程中,进程的状态默认为就绪状态s,指向下一进程的指针默认为空NULL。程序流程图如图2-2所示:图2-2 创建进程队列2.3 对进程排序 此函数的主要功能就是:按照进程

6、的到达时间进行升序排序,在该函数中采用的排序方法是冒泡排序法。程序流程图如图2-3所示:2.4 输出所创建的信息 此函数所实现的主要功能就是:按照进程的到达时间依次输出各个进程的详细信息。再此函数中,首先定义一个进程控制块指针,指向进程队列中的第一个节点,通过while语句(当p!=NULL时)来控制p=p-next循环,依次输出进程就绪队列中的各进程的详细信息。流程图如图2-4所示:图2-4 输出所创建的进程信息第三章 调试与运行结果3.1 输入界面 在此,先输入要创捷的进程总数,然后依次输入各进程的进程名、到达时间、估计运行时间,如图3-1所示:图3-1 输入界面3.2 输出界面此界面是,

7、输出经过排序后的进程队列,如图3-2所示:图3-2 输出界面3.3 运行结果输出经过时间片轮转算法后的运行结果,如图3-3所示:图3-3运行结果3.4 各种情况的运行结果下图是各种不同情况的运行结果,如图3-4,图3-5,图3-6:图3-4 运行结果图3-5 运行结果图3-6 运行结果第四章 总结4.1 遇到的问题以与解决方法首先,是对时间片算法以与处理机的具体调度过程不够熟练,通过看书和搜集一些资料解决了这个问题;其次,是在对单链表按到达时间进行排序时遇到了一些麻烦,后来经过认真思考与分析,成功地对单链表进行了排序;最后,是在编写程序的过程中出现了一些语法错误,后通过调试逐一解决。4.2 收

8、获和体会此次操作系统课程设计,在指导教师的精心教导下,以与同学们的积极讨论中,对处理机的调度问题有了深刻的理解和认识,同时对其它的几个题目也有了一定的了解。首先要对程序的设计要求有一个比较明确的认识,然后系统分析与系统设计,最后是代码设计与调试。根据操作系统课程所学的概念、理论和方法,按照程序设计的基本步骤,设计出一个适当规模的程序;进一步加深了对处理机调度问题的理解和掌握。理论联系实际,加深和巩固所学的理论知识,提高实践能力和计算机的综合运用能力。我们编写程序的过程是辛苦与快乐的,程序的编写原则很重要,只要我们在编程,就必须不断改进,才能更好提高实践编程能力。参考文献:1 尧学主编计算机操作

9、系统教程(第三版):清华大学,20062 尧学编计算机操作系统教程(第三版)习题解答与实验指导:清华大学,20063 汤子瀛主编计算机操作系统(第三版):电子科技大学,2001 4 坤等编操作系统实验教程:清华大学,20085 丽芬等编操作系统实验教程:清华大学,20066 屠祁等编.操作系统基础(第三版):清华大学,20007 耀霖等编.操作系统.:电子科技大学,20018 左万历计算机操作系统教程(第二版):高等教育,2004附录 程序源代码#include#include#include/定义进程控制块/typedef struct pcb char pname20; /进程名 int

10、arrivetime; /到达时间 int runtime; /运行时间 char state; /运行后的状态 struct pcb *next;PCB;/封装头结点,指针分别指向队头和队尾/typedef struct PCB *front,*rear;queue;/进程队列置空/queue *init() queue *head; head=(queue*)malloc(sizeof(queue); head-front=NULL; head-rear=NULL; return head;/检验进程队列是否为空/int empty(queue *head) return(head-fro

11、nt ? 0:1);/进程队列入队,往后插入/queue *append(queue *head,char c20,int a,int r,char s) PCB *p; p=(PCB*)malloc(sizeof(PCB); strcpy(p-pname,c); p-arrivetime=a; p-runtime=r; p-state=s; p-next=NULL; if(empty(head) head-front=head-rear=p; else head-rear-next=p; head-rear=p; return head;/创建进程队列/queue *creat(queue

12、*head) char c20;char s=R; int a,r,i,n; printf(请输入共有几个进程:n); scanf(%d,&n); for(i=1;ifront,*max=head-front;int flag; h=(PCB*)malloc(sizeof(PCB); h-next = head-front ; while (1) flag=0; for (p=h;p-next-next!=NULL;p=p-next) r1=p-next; r2=p-next-next; if (r1-arrivetime r2-arrivetime) if(r2-arrivetime arr

13、ivetime) min=r2; if(r1-arrivetime max-arrivetime) max=r1; flag=1; p-next=r2; r1-next=r2-next; r2-next=r1; if (flag=0) break; head-front=min; head-rear=max; h-next=head-front; return head;/输出创建的进程队列/void print(queue *head) PCB *p; p=head-front; if(!p)printf(时间片轮转调度队列为空!n); while(p) printf(pname=%s ar

14、rivetime=%d runtime=%d state= %c,p-pname,p-arrivetime,p-runtime,p-state); printf(n); p=p-next; /时间片轮转调度算法的实现/void RR(queue *head,int q) int t=head-front-arrivetime, lt=head-rear-arrivetime; if(head-front-runtimefront-runtime; else t=t+q; /进程队列不为空才可调度/ while(!empty(head) PCB *p1,*p2; /* 第一种情况:当前运行的时间

15、小于最后一个进程到达的时间做以下操作*/ while(tfront; printf(运行的时刻为%dt运行的进程为%st,t,p1-pname); p1-runtime=p1-runtime-q; / 1. 运行时间小于0,删除队首 / if(p1-runtimestate=C; printf(运行后的状态为%cn,p1-state); head-front=p1-next; free(p1); / 2. 运行时间大于0,向后找位置插入 / else printf(运行后的状态为%cn,p1-state); p2=p1-next; while(p2-next&p2-arrivetime!=t)

16、 p2=p2-next;/*此时无新进入队列的进程时,有两种情况:1.不用找位置往后插入,队首不变,不做操作 2.找位置往后插入*/ if(p2-arrivetime!=t) PCB *p3=p1,*p4; while(p3-next&p3-arrivetimenext; if(p3-arrivetimet) if(p4!=p1)/p1插在p4后,头为p1-next head-front=p1-next; p1-next=p4-next; p4-next=p1; else/不做操作/ p4=p3=p2=NULL; else p4=p3=p2=NULL; /此时有新进入队列的进程时:p1插在新进

17、入队列的进程p2后,队首为p1-next/ else head-front=p1-next; p1-next=p2-next; p2-next=p1; /*时刻变化*/ if(head-front-runtimefront-runtime; else t=t+q; /第一种情况结束/ /* 第二种情况:当前运行的时间大于最后一个进程到达的时间做以下操作*/ while(t=lt) p1=head-front; printf(运行的时刻为%dt运行的进程为%st,t,p1-pname); p1-runtime=p1-runtime-q; / 1. 运行时间小于0,删除队首 / if(p1-run

18、timestate=C; printf(运行后的状态为%cn,p1-state); head-front=p1-next; free(p1); / 2. 运行时间大于0,直接插在队尾 / else printf(运行后的状态为%cn,p1-state); /若原队列只有一个进程,不必往队尾插/ if(!p1-next) head-front=p1; /若原队列有多个进程/ else head-front=p1-next; head-rear-next=p1; head-rear=p1; p1-next=NULL; /*时刻变化,队列为空时不做时刻变化*/ if(empty(head) return; else if(head-front-runtimefront-runtime; else t=t+q; /第二种情况结束/ void main() queue *head;int q; head=init(); head=creat(head); head=sort(head); printf(您输入的时间片轮转进程队列为:n); print(head); printf(请输入时间片轮转调度的时间片为:n); scanf(%d,&q); RR(head,q);

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2