全文预览

时间片轮转详解

上传者:徐小白 |  格式:ppt  |  页数:18 |  大小:118KB

文档介绍
乎同时按下回车键,将发生什么情况?假设所有其他进程都用足它们的时间片的话,最后一个不幸的进程不得不等待5秒钟才获得运行机会。多数用户无法忍受一条简短命令要5秒钟才能做出响应。同样的问题在一台支持多道程序的个人计算机上也会发生。Р时间片设得太短会导致过多的进程切换,降低了CPU效率;而设得太长又可能引起对短的交互请求的响应变差。将时间片设为100毫秒通常是一个比较合理的折衷。Р时间片轮转算法的主要实现过程Р首先为每一个进程创建一个进程控制块,定义数据结构,说明进程控制块所包含的内容,有进程名、进程所需运行时间、已运行时间和进程的状态以及指针的信息。实现的过程即运用指针指向某一个进程,判断当前的进程是否是就绪状态“r”,如果是,则为该进程分配一个时间片,同时,已运行时间加一且要求运行的时间减一,如此循环执行,当某一个进程的所需要运行的时间减少至0时,则将该进程的状态设置为“e”。然后,将指针指向下一个未运行完成的进程,重复判断,直至所有的进程都运行结束Р所用数据结构及符号说明Рtypedef struct PCB{? char name[10]; //进程名? struct PCB *next; //循环链指针? int need_time; //要求运行时间? int worked_time; //已运行时间,初始为0? char condition; //进程状态,只有“就绪”和“结束”两种状态? int flag; //进程结束标志,用于输出? }PCB;? PCB *front,*rear; //循环链队列的头指针和尾指针? int N; //N为进程数Р主程序的流程图Р程序说明Р处理器调度总是选择指针指示的进程运行。由于本实验是模拟处理器调度的功能,所以,对被选中的进程并不实际的启动运行,而是执行:已运行时间+1来模拟进程的一次运行,表示进程已经运行过一个单位的时间。

收藏

分享

举报
下载此文档