《操作系统课程设计》报告范本.doc
《《操作系统课程设计》报告范本.doc》由会员分享,可在线阅读,更多相关《《操作系统课程设计》报告范本.doc(19页珍藏版)》请在咨信网上搜索。
《操作系统课程设计》报告范本 19 2020年5月29日 文档仅供参考 <操作系统课程设计>报告 学 号: 姓 名: 班 级: 指导教师: 报告日期: 一、课设目的 经过对操作系统课程的学习,熟悉进程的概念、进程的管理与存储、进程的调度,经过实践深入理解进程的调度算法。 二、课设任务 要求编写一个程序,能够创立若干个虚拟进程,并对若干个虚拟进程进行调度,调度策略为时间片轮转法,主要任务包括: 进程的个数,进程的内容(即进程的功能序列)来源于一个进程序列描述文件,另外调度运行结果输出到一个运行日志文件; 设计PCB适用于时间片轮转法; 建立进程队列; 实现时间片轮转调度算法,尽量可视化的展示调度的动态过程。 总结程序设计的开发过程:需求分析、系统设计、系统实现及文档的收集和整理。 三、实验方法与设计分析 每个进程有一个进程控制块( PCB)表示。进程控制块能够包含如下信息:进程名、优先数、到达时间、需要运行时间、已用CPU时间、进程状态等等。 进程的优先数及需要的运行时间能够事先人为地指定(也能够由随机数产生)。进程的到达时间为输入进程的时间。 进程的运行时间以时间片为单位进行计算。 每个进程的状态能够是就绪 W(Wait)、运行R(Run)、或完成F(Finish)三种状态之一。 就绪进程获得 CPU后都只能运行一个时间片。用已占用CPU时间加1来表示。 如果运行一个时间片后,进程的已占用 CPU时间已达到所需要的运行时间,则撤消该进程,如果运行一个时间片后进程的已占用CPU时间还未达所需要的运行时间,也就是进程还需要继续运行,此时应将进程的优先数减1(即降低一级),然后把它插入就绪队列等待CPU。 每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的 PCB,以便进行检查。 重复以上过程,直到所要进程都完成为止 四、程序流程图 开始 设置时间片 选择 增加进程 是 结束进程 PCB顺序 继续增加 调度进程 结束 打印进程 PCB顺序 循环 五、程序源代码 #include "stdafx.h" #include <stdio.h> #include <stdlib.h> #include <string.h> #include <ctype.h> #include <iostream> #include <fstream> using namespace std; ofstream myfile("bb.txt",ios::app||ios::trunc); typedef struct node { char name[10];/*进程名*/ int round; /*进程分配的时间片*/ int cputime; /*进程消耗的CUP时间*/ int needtime; /*进程需要的CUP时间*/ int count; /*进程运行时间*/ char state; /*进程的状态:'R':运行,'W':等待,'F':结束*/ struct node *next;/*指向下一个进程的指针*/ }PCB; PCB *finish,*ready,*tail,*run;/*指向三个队列的队首的指针,tail为就绪队列的队尾指针*/ int N;/*定义进程的数目*/ void firstin(void) { if(ready!=NULL) { run=ready; ready=ready->next; run->state='R'; run->next=NULL; } else { run=NULL; } } void prt1(char a) { cout<<"name" <<" cputime" <<" needtime"<<" count "<<" round"<<" state"<<endl; myfile<<"name" ;myfile<<" cputime";myfile <<" needtime"; myfile<<" count ";myfile<<" round";myfile<<" state"<<endl; } void prt2(char a,PCB *p) { cout<<p->name<<" "<<p->cputime<<" "<<p->needtime<<" "<<p->count<<" "<<p->round<<" "<<p->state<<endl; myfile<<p->name<<" ";myfile<<p->cputime<<" ";myfile<<p->needtime<<" "; myfile<<p->count<<" ";myfile<<p->round<<" "; myfile<<p->state<<endl; } void prt(char algo) { PCB *p; prt1(algo); if(run!=NULL) { prt2(algo,run); } p=ready; while(p!=NULL) { prt2(algo,p); p=p->next; } p=finish; while(p!=NULL) { prt2(algo,p); p=p->next; } getchar(); } void insert(PCB *q) { tail->next=q; tail=q; q->next=NULL; } void rcreate_task(char algo) { PCB *p; int n,time; char na[10]; ready=NULL; finish=NULL; run=NULL; cout<<"请输入进程数目N:"; cin>>N; for(n=0;n<N;n++) { p=(PCB*)malloc(sizeof(PCB)); cout<<"Enter the name of process:"<<endl; cin>>na; cout<<"Enter the time of process:"<<endl; cin>>time; strcpy(p->name,na); p->cputime=0; p->needtime=time; p->count=0; p->state='W'; p->round=2; if(ready!=NULL) { insert(p); } else { p->next=ready; ready=p; tail=p; } } run=ready; ready=ready->next; run->state='R'; cout<<"创立成功。"<<endl; } void chakan(char algo) { if(run->count==run->round) { run->count=0; if(ready!=NULL) { run->state='W'; insert(run); firstin(); } } prt(algo); } void roundrun(char algo) { while(run!=NULL) { run->cputime=run->cputime+1; run->needtime=run->needtime-1; run->count=run->count+1; if(run->needtime==0) { run->next=finish; finish=run; run->state='F'; run=NULL; if(ready!=NULL) { firstin(); } } else { if(run->count==run->round) { run->count=0; if(ready!=NULL) { run->state='W'; insert(run); firstin(); } } } prt(algo); } } void caidan() { cout<<"**************************主页************************"<<endl; cout<<"*******************1.I 创立若干进程*******************"<<endl; cout<<"*******************2.C 进程进行查看*******************"<<endl; cout<<"*******************3.O 进程进行调度*******************"<<endl; cout<<"*******************4.H 结束 ********************"<<endl; } int main() { loop1:caidan(); char algo; cin>>algo; if(algo=='i'||algo=='I') { rcreate_task(algo); } else if(algo=='c'||algo=='C') { chakan(algo); } else if(algo=='o'||algo=='O') { roundrun(algo); } else if(algo=='h'||algo=='H') { goto loop2; } goto loop1; loop2: myfile.close(); return 0; } 六、运行结果 七、问题及解决方法 (1) 处理器调度总是选队首进程运行。采用动态改变优先数的办法,进程每运行一次优先数就减”1”。由于本实习是模拟处理器调度,因此,对被选中的进程并不实际的启动运行,而是执行 (2) 进程运行一次后,若要求运行时间〉0,则再将它加入队列(按优先数大小插入,且置队首标志);若要求运行时间=0,则把它的状态修改成”结束”(E),且退出队列。 (3) 若”就绪”状态的进程队列不为空,则重复上面(1)和(2)的步骤,直到所有进程都成为”结束”状态。 (4) 在所设计的程序中应有显示或打印语句,能显示或打印每次被选中进程的进程名以及运行一次后进程队列的变化。 (5) 为五个进程任意确定一组”优先数”和”要求运行时间”,启动所设计的处理器调度程序,显示或打印逐次被选中进程的进程名以及进程控制块的动态变化过程。 八、心得体会 操作系统是计算机系统中必不可少的系统软件。它是计算机系统中各种资源的管理者和各种活动的组织者、指挥者。操作系统采用时间片法调度进程,使系统资源得到充分的利用,用户也能够花更少的时间完成更多的工作,这次模拟系统调度进程,让我明白了系统时间片的调度方法,对操作系统理论的学习更加深一层。 经过这次的课设也让我充分的体会到了要真正的理解计算机操作系统的工作原理应该多上机做试验和操作,这样才能领悟的更深更好。或许程序完成的有点粗糙可是也花了一些心里,感觉自己还时弄懂了它的实现过程,以前觉得操作系统都时些理论上的东西对于具体的实践说实话还确实没怎么弄过。因此这次的课程设计让我学到了更多的东西。- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统课程设计 操作系统 课程设计 报告 范本
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文