优先级调度算法(C++实现)

本文介绍了优先级调度算法的实现,通过C++编程语言模拟了调度过程。每个进程有进程控制块(PCB),包含进程名、优先级、估计运行时间等信息。调度时选择优先级最高的进程,每次运行后优先级会降低。当有更高优先级的进程出现时,会进行抢占。程序还展示了运行过程中的状态变化和队列情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

算法思想:

优先级调度算法:

(1)假设系统中有5个进程,每个进程有一个进程控制块(PCB)来标识。进程控制块内容包括:进程名,链接指针,进程的优先级,估计运行时间,进程状态。 进程的优先数由用户自己指定或程序任意设定,且优先数越低,优先级越高,调度时,总是选择优先级最高的进程运行。

(2)为了调度方便,设计一个指针指向5个进程排成的就绪队列的第一个进程,另外再设一个当前运行进程指针,指向当前正在运行的进程。

(3)处理机调度时总是选择队列中优先级最高的进程运行。为了采用动态优先级调度,进程每运行一次,其优先级就减1。由于本实验是模拟试验,所以对被选中进程并不实际启动运行,而只是执行:优先数加1和估计运行时间减1。用这两个操作来模拟进程的一次运行。

(4)进程运行一次后,若剩余的运行时间不为0,且其优先级低于就绪队列的优先级,则选择一个高优先级进程抢占CPU;若剩余时间为0,则把它的状态改为完成态(C),并撤出就绪队列。

(5)若就绪队列非空,则重复上述的(3)和(4),直到所有进程为完成态。

(6)在所设计的程序中应有显示或打印语句,能显示或打印正运行进程的进程名、运行一次后进程的变化、就绪队列中各进程排队情况等。

评论 21
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AHU_YZQ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值