- 1、本文档共6页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
姓名:王思文 物电学院通信一班
学号:2010221105200075
进程调度算法简介
进程调度算法就进程来分,分为三类:批处理、交互式、实时。下面将分别进行描述。
批处理系统
先到先服务
这种调度算法属于非抢占式,只有当前进程主动放弃处理器别的进程才会有机会运行。这个算法只有一个运行队列,一个进程进入就绪状态时就自动转移到运行队列的队尾等待调用。该算法简单,容易理解,但在处理器使用率上达不到要求。
最短作业优先
该算法可用在运行时间可以预知的系统中。当系统中同时有若干同等重要的作业需要运行的时候,最短作业优先可以有效降低短作业的等待时间。但该算法的运行环境必须是可以预知作业长短的,而且任务必须是同时就绪的。
最短剩余时间优先算法
这个算法是最短作业优先的抢占式版本。使用这样调度算法,调度程序会挑选剩余时间最短的作业运行。当然,这要求作业的运行时间可以预知。该算法可以是新来的短作业得到较好的服务,解决了最短优先算法中对作业起始时间同时开始的要求
交互式系统
时间片轮转调度
在这种调度算法中,每个进程被分配一个时间段,称之为时间片,也就是进程允许运行的时间。如果时间片结束时进程仍然在运行,则CPU将被抢占并分配给另一个进程。如果在时间片结束前阻塞或结束,则CPU马上进行切换。时间片轮转是目前最古老,最简单也是使用最广的一种调度策略。
优先级调度
时间片调度是一种很公平的调度策略,但是这种公平并不一定是好的。它默认了所有的作业都处在同一种优先级下。但实际情况往往并不如此。在优先级调度中,优先级较高的作业更容易获得CPU,但为了不让这种作业无休止的运行下去,
实时系统
实时系统是一些时间因素非常重要的系统,往往要就系统对突发性的事件进行快速响应。实时系统通常分为硬实时和软实时。在硬实时系统中,进程必须满足时间要求,但在软实时系统中进程可以被允许偶尔的“犯规”。实时系统中程序将分为几个进程,每个进程的行为都是可以预知的。每个进程的生存时间很短。
实时调度算法可以分为静态的和动态的。静态算法要求系统启动前就完成调度决策,后者则像其它系统一样在运行时进行调度。
Linux操作系统进程调度算法
这里介绍的Linux进程调度算法是基于在2.6.x的内核。它的主要实现在kernel/sched.c中。该进程调度算法的主要目标如下:
????????? 实现低时间复杂度的调度。
????????? 实现对SMP的兼容。
????????? 对交互式程序有所倾斜,保证系统在高负载下的响应。
????????? 保证公平。在设计目标范围内,消除明显的不公平。
运行队列
在Linux系统中存在一种数据结构叫做运行队列。它的定义在kernel/sched.c中。运行队列(runqueue)和处理器一一对应,是一个关于可以执行的进程的链表。任何一个处于运行状态的进程都属于一个可执行队列。运行队列数据结构中包含了保护该runqueue的自旋锁、可运行任务数、队列最后被换出的时间、当前运行任务、等待I/O操作的任务数目等。运行队列中的自旋锁保证了该数据结构被调用时首先应该被锁住。在SMP,处理器锁住其它处理器运行队列是被允许的但很少出现。在进行运行队列的所操作时,必须保证以执行队列地址从低到高的顺序,不然会出现死锁的情况。
优先级数组
每个运行队列都有两个优先级数组,一个活跃的和一个过期的。优先级数据是Linux能够在低时间复杂度情况下进行调度的基础。优先级数组包含一系列的优先级队列,同时还有一个优先级位图。前者使处理器拥有各个优先级上的进程链表,后者则可以查找当前拥有最高优先级的进程。
宏MAX_PRIO定义了系统拥有的优先级的个数,一般是140。针对这140个优先级,有140个struct list_head结构体与之对应。优先级数组包含一个优先级位图数组。当调度开始时,每个优先级位图位都被置为0。只有当拥有某一个优先级的进程进行运行时,该优先级对应的位图位被置为1。
优先级数组还包含一个叫做struct list_head的队列,每个struct list_head元素都对应一个优先级,包含该处理器相应优先级的全部可运行进程。
时间片的重新计算
在系统中所有时间片都用完时,调度程序会重新计算每个进程的时间片。决定每个进程时间片时间是个比较耗时的过程,在2.6.x内核中Linux调度程序没有使用循环分配的方式进行。在这个过程中使用了处理器所维护的两个优先级数组即活动数组和过时数组。当一个进程的时间片耗尽时将被从活动优先级数组移动到过时优先级数组,在此之前,它的时间片已经被计算好了。重新计算时间片的活动就变成了在两个优先级数组之间进行切换的活动。由于数组是通过指针进行访问的,所以重新计算时间片的耗时就是在优先级数组之间交换指针的耗时。这种设计是
您可能关注的文档
最近下载
- 慢性阻塞性肺病伴有急性下呼吸道感染护理查房.pptx
- 肺结核合并糖尿病(共23张PPT)【23页】.pptx
- 慢性阻塞性肺疾病护理疑难病历讨论.pptx VIP
- 安全管理体系与措施及环境保护管理体系与措施 .doc VIP
- 食材配送分拣管理制度内容.docx VIP
- 上汽通用雪佛兰-迈锐宝XL-产品使用说明书-全混动锐尊版-SGM7186EACHEV-17MYCHE2SCSOM26248143_20170629.pdf
- (完整版)软件项目开发计划书.pdf
- 增程式燃料电池电动汽车动力系统设计研究.pptx VIP
- 【增程式电动汽车能量管理策略研究开题报告文献综述5600字】.doc VIP
- 牛津上海版小学英语5年级下册 Module 3 Unit 3 Changes 公开课PPT课件12.ppt
文档评论(0)