Windows进程调度的方式

Windows进程调度的方式,第1张

分类: 电脑/网络 >> *** 作系统/系统故障

问题描述:

请问各位大虾

Windows进链指程调度的方式有那几种?

谢谢了

解析:

高级调度:又称作业调度。其主要功能是根据一定的算法,从输人的一批作业中选出若干个作业,分配必要的资源,如内存、外设等,为它建立相应的用户作业进程和为其服务的系统进程(如输人、输出进程),最后把它们的程序和数据调人内存,等待进程调度程序对其执行调度,并在作业完成后作善后处理工作。

低级调度:又称进程调度。其主要功能是根据一定的算法将CPU分派给就绪队列中的一个进程。执行低级调度功能的程序称做进程调度程序,由它实现CPU在进程间的切换。进程调度的运行频率很高,在分时系统中往往几十毫秒就要运行一次。进程调度是 *** 作系统中最基本的一种调度。在一般类型的 *** 作系统中都必须有进程调度,而且它的策略的优劣直接影响整个系统的计能。

中级调度:又称交换调度。为了使内存中同时存放的进程数目不至于太多,有时就需要把某些进程从内存中移到外存上,以减少多道程序的数目,为此设立了中级调度。特别在采用虚拟存储技术的系统或分时系统中,往往增加中级调度这一级。所以中级调度的功能是在内存使用情况紧张时,将一些暂时不能运行的讲程从内存对换到外存上等待。当以后内存有足够的空闲空间时,再将合适的进程重新换人内存,等待进程调度。引人中级调度的主要目的是为了提高内存的利用率和系统吞吐量。它实际上就是存储器管理中的对换功能

下面说说进程调度的策略问题(引用参考资料内容):

首先硬件机制上如何保证 *** 作系统的内核调度进程可以一定的时机可以获得CPU,来进行进程调度.?

通常我们会在软件层次上找答案.其实,是通过在CPU的硬件处理机制上实现的.CPU在执行完每个指令的周期后回扫描CPU的内部的一个中断寄存器,查询是否存在中断发生,若没有,则继续执行指令若有,则保存当前的CPU工作环境,跳转到中断服务列程,CPU执行中断服务程序,在推出中断后,跳转到内核调度程序(这是个内核程序,但是是对所有的进程共享的,包括用户进程)此时,内核调度程序占据CPU,进行进程的调度,以决定下个将占用CPU的进程.

接下来就要谈谈什么时候会需要进行进程调春孙度?

在教科书书说到的有几种情况:1时间片到,即每个进程所分配的时间片用完后,要跳转到调度程序2 占用CPU的当前运行进扒唤链程提出I/O *** 作,发起对内核的系统调用时,在系统调用结束后,跳转到调度程序3 我自己的想法: 当前运行进程对所有内核系统调用的结束时都要跳转到调度程序,根据当前的调度信息来决定下一个可以占用CPU的进程. 我所指的系统调用也包括中断列程.不过对与具体的调度时机,很多书上都写的不清不楚,真不知道他们不懂,还是不屑于写出来告诉我们. 其实除了在大多数硬件中断的触发后跳转到调度程序, 每个时钟中断发生的时候,我觉得都需要跳转到调度程序.(在进入时钟中断列程中,要对进程表中的所有的进程的调度信息进行更新和对各个进程队列的处理),对更新后的进程信息进行处理以决定调度哪个进程. 通常的教科书中都将硬件物理的处理机制和软件的调度处理机制分开,在物理和逻辑两个层次上分开谈,不利于我们理解.最好是把这两个结合起来理解进程调度的工作机制.目前需要解决的是:在什么时候需要内核调度程序占据CPU来调度? 至于调度的算法那就是逻辑层次上要考虑的东西.

其实看了这么多,我也有了些小论文的想法, 因为做的方向是应用在电子电力电路上的嵌入系统控制.该应用对嵌入 *** 作系统的性能就有些特殊的需求:首先体积要小,速度快内核就要小,进程调度要实现抢占式任务调度,且调度切换要快.它的进程调度与通用 *** 作系统的进程调度不同,这是因为它们的要求不一样,嵌入式通常是要求是实时,且严格的讲在电路上的控制系统应该是硬实时,而不象通用系统是非实时,或者是软实时.这跟它们对实时性的要求不同.所以我初步定个题目 "嵌入式系统和通用系统在进程调度上比较和分析,并针对特定的电路控制嵌入实时系统提出一个调度策略". 我想我从明天开始就要准备这方面的资料,分析分析,比较比较,弄篇小论文出来,,不然我都快给它凡死了.

*** 作系统-----进程调度

[/color][color=Gray][/color][color=Blue][/color][color=Lime] 要求:实现按优先级与时间片相结合的进程调度算法

内容:

1:设计进程控制快,进程队列结构(包括:就绪队列,等待队列,运行队列)等必要的数据结构。

2:模拟 *** 作系统进程调度的功能,编写进程调度程序,模拟的处理机分派程序,进程等待函数和进程唤醒函数。

3:编写用户程序,创建6个用户进程。

进程调度的设计方法

1。数据结构

(1)优先级与时间片的设计

◆进程因等待放弃CPU时,优先级置为1(高优先级)

◆进程因时间片到放弃CPU时,优先级置为0(低优先级)

◆优先1对应时间片4;优先级0对应时间片10。

(2)进程控制块(PCB)的内容

进程标识3---9

进程优先级 0,1

进程优先级 0,1

进程等待时间 20

链接指针

2:程序算法

(1)PCB结构,变量与主程序

struct PCB

{

int pname

int pri

int runtime

int waitting

struct PCB*next

}

pcb[7]

struct PCB*running,ready,wait

int sin=0

main()

{ 创建PCB[3]--PCB[9]并插入ready队列;/*pname分别为3--9,

pri=0,runtime=10,waittime=0 */

for()/*系统程序,完成初始化和处理机分派功能 */

{cast{sig=0:swtch

sig=1:waiter

sig=3:proc3

sig=4:proc4

sig=5:proc5

sig=6:proc6

sig=7:proc7

sig=8:proc8

sig=9:proc9}

}

}

(2) 进程调度程序

swtch()

{

while(ready==NULL)wakeup()

移出就绪队列第一个PCB

送running指针;

若pri=1,则runntime=4,否则runtime=10

将running→pname 送sig

}

(3) 将进程等待函数

wait()

{将运行进程插入wait队列,优先数置1;

sig=0

}

(4) 进程唤醒函数

wakeup()

{

将wait队列中所有的PCB中waittime减1;

将wait队列中的所有的waittime=0的PCB揭除;

插入到ready队列中第一个优先级为0的PCB前面

        进程大致可分为I/O密集型和 CPU密集型。

        调度依据 动态优先雀旅级 ,所谓动态优先级就是初始化时给出一个基础优先级,随后优先级可被调度程序动态的增减。高优先级进程也获得较长的时间片。I/O密集型通常被提升优先级,而CPU密集型则被降低。            

        Linux系统有两种独立的优先级范围。第一种是 Nice 值,返回是[-20, 19],默认值为0。数值越高优先级越低。Nice值影响了时间片的分配。如果进程拥有-20的Nice值,那么该进程将被分配理论最长的时间片。Nice值是所有Unix系统的标准优先级。

        Linux的第二种优先级范围是睁岁乱 实时优先级 。这个优先级的值是可配置的。通常来说范围在[0,99]。 所有实时进程的优先级都高于普通进程 。(实时进程是什么?)

        时间片是一个数值,决定了进程被抢占前可运行的时间。必须为进程分配合适长度的时间片。时间片太长会影响系统的交互性,时间片太短则会导致系统花费大量的时间用于进程的切换。同时还要兼顾I/O密集型和 CPU密集型进程的矛盾。因为I/O密集型无需长时间片,却渴望经常运行。而Linux却提供了相对较长的默认时间片——100毫秒。   

        注意到,进程不必在每次被调度运行后就花光自己所有的时间片。举例来说,如果一个进程拥有长达100毫秒的时间片,那么它可以在五个不同时段运行,每次花费20毫秒的时间片。这么做的好处是,一个拥有长时间片的进程(尽管它本身不需要如此长的时间片),可以尽可能长时间的保持运行状态。而不会过早地被丢入等待调度的队列中(稍后说到)。这就好比键盘驱动进程的实现方法。

        当某进程的状态变为TASK_RUNNING的时候,内核会检查它的优先级是否高于当前正在执行的任务。如果是,调度进程就会使该进程抢占CPU。另外,如果一个进程的时间片变成0(意味着用尽了所有时间片,只能等待所有进程时间片为0才会重新分配),调度进程会被再次调用,选择一个新的进程运行。

        个人猜测 :这里拿文字软件和音乐播放软件来悉档举例。CPU在每条指令执行结束后检查中断引脚。如果检测到键盘的活动,就会引发中断而将键盘输入程序的状态设置为TASK_RUNNING,然后执行上述的检查程序。因为文字软件的优先级高于音乐播放软件,所以文字软件将立即得到执行,将键入字符输入在屏幕中。完成这一工作后,文字软件将设置自身状态或是其他方法,使得音乐播放软件可以抢占CPU?

public class PrivilegeProcess {

public static void main(String[] args) {

MyQueue myqueue = new MyQueue()//声明队列

PCB[] pcb = {new PCB(001,8,1),new PCB(002,7,9),new PCB(003,3,8),new PCB(004,1,7),new PCB(005,7,4)}

PCB para = new PCB()

for(int i=0i<pcb.lengthi++){//初始化后首先执行一次排序,这里使用的是选择排序,优先级高的先入队

for(int j=ij<pcb.lengthj++){

if(pcb[i].privilege <pcb[j].privilege){

para = pcb[i]

pcb[i] = pcb[j]

pcb[j] = para

}

}

}

System.out.println("初次入队后各进程的顺序:")

for(int i=0i<pcb.lengthi++){

System.out.println("初次入队后 # processname : " + pcb[i].name + " totaltime : " + pcb[i].totaltime + " privilege :" + pcb[i].privilege)

}

System.out.println()

myqueue.start(pcb)

}

}

class MyQueue {

int index = 0

PCB[] pc = new PCB[5]

PCB[] pc1 = new PCB[4]

PCB temp = new PCB()

public void enQueue(PCB process){//入队算法

if(index==5){

System.out.println("out of bounds !")

return

}

pc[index] = process

index++

}

public PCB deQueue(){//出队算法锋派

if(index==0)

return null

for(int i=0i<pc1.lengthi++){

pc1[i] = pc[i+1]

}

index--

temp = pc[0]

for(int i=0i<pc1.lengthi++){

pc[i] = pc1[i]

}

return temp

}

public void start(PCB[] pc){//显示进程表算法

while(pc[0].isNotFinish==true||pc[1].isNotFinish==true||pc[2].isNotFinish==true||pc[3].isNotFinish==true||pc[4].isNotFinish==true){

//*注意:||运算符,所有表达式都为false结果才为false,否则为true

for(int i=0i<pc.lengthi++){

pc[i].run(this)

}

System.out.println()

for(int i=0i<pc.lengthi++){//所有进程每执行完一次时间片长度的运行就重新按优先弊陵级租基戚排列一次

for(int j=ij<pc.lengthj++){

if(pc[i].privilege <pc[j].privilege){

temp = pc[i]

pc[i] = pc[j]

pc[j] = temp

}

}

}

}

}

}

class PCB {//声明进程类

int name,totaltime,runtime,privilege

boolean isNotFinish

public PCB(){

}

public PCB(int name, int totaltime, int privilege){

this.name = name//进程名

this.totaltime = totaltime//总时间

this.privilege = privilege//优先级别

this.runtime = 2//时间片,这里设值为2

this.isNotFinish = true//是否执行完毕

System.out.println("初始值: processname : " + name + " totaltime : " + totaltime + " privilege :" + privilege )

System.out.println()

}

public void run (MyQueue mq){//进程的基于时间片的执行算法

if(totaltime>1){

totaltime-=runtime//在总时间大于1的时候,总时间=总时间-时间片

privilege--

System.out.println(" processname : " + name + " remaintime : " + totaltime + " privilege :" + privilege )

}else if(totaltime==1){

totaltime--//在总时间为1时,执行时间为1

privilege--

System.out.println(" processname : " + name + " remaintime : " + totaltime + " privilege :" + privilege )

}else{

isNotFinish = false//总时间为0,将isNotFinish标记置为false

}

if(isNotFinish==true){

mq.deQueue()

mq.enQueue(this)

}

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12480830.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存