用C语言模拟Linux操作系统下处理机调度实验报告

上传者: easyxuhao | 上传时间: 2022-05-21 09:03:52 | 文件大小: 182KB | 文件类型: DOC
在采用多道系统的设计程序中,往往有若干进程同时处于就绪状态。当就绪状态进程数大于处理机数时,就必须按照某种策略来决定哪些进程优先占用处理机。本实验用C语言模拟在单处理机情况下处理机调度,包括优先数法和时间片轮转法。 一、优先调度算法实现处理机的调度: 设计思路: 1、每个进程用一个进程控制块PCB来代表,进程控制块包括进程名(进程的标识)、指针(按优先数的大小把进程连成队列,用指针指出下一个进程的进程控制块首地址,最后一个进程中的指针为"0")、要求运行时间、优先数、状态(就绪、结束); 2、每次运行处理机调度程序前,为每个进程确定它的"优先数"和"要求运行时间"; 3、把给定的进程按优先数的大小连成队列,用一单元指出队首进程; 4、每模拟执行一次进程,优先数减一,要求运行时间减一; 5、如果要求运行的时间>=0,再将它加入队列(按优先数的大小插入,重置队首标志);如果要求运行的时间=0,那么把它的状态修改为结束,且推出队列; 6、若就绪队列不为空,重复上述,直到所有的进程都结束; 7、程序有显示和打印语句,每次运行后显示变化。 二、按时间片轮转法实现处理机调度: 设计思路: 1、每个进程用一个进程控制块PCB来代表,进程控制块包括进程名(进程的标识)、指针(把进程连成循环队列,用指针指出下一个进程的进程控制块首地址,最后一个进程中的指针指出第一个进程的进程控制块首地址)、已运行时间、状态(就绪、结束); 2、每次运行处理机调度程序前,为每个进程确定它的"要求运行时间"; 3、用指针把给定的进程按顺序排成循环队列,用另一标志单元记录轮到的进程; 4、每模拟运行一次进程,已运行时间加一; 5、进程运行一次后,把该进程控制块的指针值送到标志单元,以指示下一个轮到的进程。若该进程要求运行时间≠已运行时间,未执行结束,待到下一轮再执行;若要求运行时间=已运行时间,状态改为结束,退出队列; 6、若就绪队列不为空,重复步骤四和五; 7、程序有显示和打印语句,每次运行后显示变化。

文件下载

评论信息

  • qin_pc000 :
    已经试用过了,不过自己有些地方还有些毛病,需要自己慢慢修改了,很好的一个借鉴!
    2014-10-22
  • wjxgxg :
    虽然不是想要的,但producer consumer值得借鉴
    2013-10-07
  • lisasa_2684 :
    很好 很好 不错 不错 能够 运行老师说代码很好
    2013-06-24
  • xyz080601117 :
    内容写得很好,体现了作者的专业水平,也比较符合我的要求,总体还是比较规范的,值得下载
    2012-04-29

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明