用C语言写时间片轮转调度算法和多级反馈队列调度算法
时间: 2023-09-25 18:13:30 浏览: 253
时间片轮转调度算法的C语言实现:
```c
#include <stdio.h>
// 进程控制块结构体
typedef struct PCB{
int pid; // 进程ID
int burst; // 进程执行时间
int wait; // 进程等待时间
int tat; // 进程周转时间
int rt; // 进程剩余时间
} PCB;
// 时间片轮转调度算法
void RR(PCB *p, int n, int q) {
int t = 0; // 记录当前时间
int done = 0; // 记录已经完成的进程数
while(done < n) {
int flag = 0; // 标记是否有进程在执行
for(int i = 0; i < n; i++) {
if(p[i].rt > 0) { // 判断进程是否还有剩余时间
flag = 1; // 标记有进程在执行
if(p[i].rt > q) { // 进程还需执行时间大于时间片
t += q; // 更新当前时间
p[i].rt -= q; // 更新进程剩余时间
} else {
t += p[i].rt; // 更新当前时间
p[i].wait = t - p[i].burst; // 计算进程等待时间
p[i].tat = t; // 计算进程周转时间
p[i].rt = 0; // 进程已经执行完
done++; // 已经完成的进程数+1
}
}
}
if(flag == 0) break; // 所有进程都已经执行完
}
printf("进程ID\t等待时间\t周转时间\n");
for(int i = 0; i < n; i++) {
printf("%d\t%d\t%d\n", p[i].pid, p[i].wait, p[i].tat);
}
}
int main() {
// 初始化进程控制块
PCB p[] = {
{1, 24, 0, 0, 24},
{2, 3, 0, 0, 3},
{3, 3, 0, 0, 3}
};
int n = sizeof(p) / sizeof(PCB);
int q = 4; // 时间片大小
RR(p, n, q);
return 0;
}
```
多级反馈队列调度算法的C语言实现:
```c
#include <stdio.h>
// 进程控制块结构体
typedef struct PCB{
int pid; // 进程ID
int burst; // 进程执行时间
int wait; // 进程等待时间
int tat; // 进程周转时间
int rt; // 进程剩余时间
int prio; // 进程优先级
} PCB;
// 多级反馈队列调度算法
void MFQ(PCB *p, int n, int q1, int q2) {
int t = 0; // 记录当前时间
int done = 0; // 记录已经完成的进程数
while(done < n) {
int flag = 0; // 标记是否有进程在执行
// 第一级队列,时间片大小为q1
for(int i = 0; i < n; i++) {
if(p[i].prio == 1 && p[i].rt > 0) { // 判断进程是否在第一级队列中
flag = 1; // 标记有进程在执行
if(p[i].rt > q1) { // 进程还需执行时间大于时间片
t += q1; // 更新当前时间
p[i].rt -= q1; // 更新进程剩余时间
} else {
t += p[i].rt; // 更新当前时间
p[i].wait = t - p[i].burst; // 计算进程等待时间
p[i].tat = t; // 计算进程周转时间
p[i].rt = 0; // 进程已经执行完
p[i].prio = 2; // 进程优先级变为第二级
done++; // 已经完成的进程数+1
}
}
}
// 第二级队列,时间片大小为q2
for(int i = 0; i < n; i++) {
if(p[i].prio == 2 && p[i].rt > 0) { // 判断进程是否在第二级队列中
flag = 1; // 标记有进程在执行
if(p[i].rt > q2) { // 进程还需执行时间大于时间片
t += q2; // 更新当前时间
p[i].rt -= q2; // 更新进程剩余时间
} else {
t += p[i].rt; // 更新当前时间
p[i].wait = t - p[i].burst; // 计算进程等待时间
p[i].tat = t; // 计算进程周转时间
p[i].rt = 0; // 进程已经执行完
done++; // 已经完成的进程数+1
}
}
}
if(flag == 0) break; // 所有进程都已经执行完
}
printf("进程ID\t等待时间\t周转时间\n");
for(int i = 0; i < n; i++) {
printf("%d\t%d\t%d\n", p[i].pid, p[i].wait, p[i].tat);
}
}
int main() {
// 初始化进程控制块
PCB p[] = {
{1, 10, 0, 0, 10, 1},
{2, 1, 0, 0, 1, 1},
{3, 2, 0, 0, 2, 1},
{4, 1, 0, 0, 1, 1},
{5, 5, 0, 0, 5, 1},
};
int n = sizeof(p) / sizeof(PCB);
int q1 = 2; // 第一级队列时间片大小
int q2 = 4; // 第二级队列时间片大小
MFQ(p, n, q1, q2);
return 0;
}
```
阅读全文
相关推荐
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![txt](https://img-home.csdnimg.cn/images/20210720083642.png)
![cpp](https://img-home.csdnimg.cn/images/20210720083646.png)
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![-](https://img-home.csdnimg.cn/images/20210720083327.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)