0


操作系统:实验一:进程调度实验——最高优先数优先的调度算法以及先来先服务算法 源码

一、实验目的

(1)了解进程实体PCB结构;

(2)理解进程不同状态和状态之间的转换过程;

(3)掌握优先数的调度算法和先来先服务算法;

二、实验内容与要求

设计一个有 N个进程共行的进程调度程序

四、实验步骤

(1)实验设计

进程调度算法:采用最高优先数优先的调度算法(即把处理机分配给优先数最高的进程)和先来先服务算法。每个进程有一个进程控制块( PCB)表示。

进程控制块可以包含如下信息:进程名、优先数、到达时间、需要运行时间、已用CPU时间、进程状态等等。

进程的优先数及需要的运行时间可以事先人为地指定(也可以由随机数产生)。

进程的到达时间为进程输入的时间。进程的运行时间以时间片为单位进行计算。每个进程的状态可以是就绪 W(Wait)、运行R(Run)、或完成F(Finish)三种状态之一。

就绪进程获得 CPU后都只能运行一个时间片。用已占用CPU时间加1来表示。如果运行一个时间片后,进程的已占用 CPU时间已达到所需要的运行时间,则撤消该进程,如果运行一个时间片后进程的已占用CPU时间还未达所需要的运行时间,也就是进程还需要继续运行,此时应将进程的优先数减1(即降低一级),然后把它插入就绪队列等待CPU。每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的 PCB,以便进行检查。   

重复以上过程,直到所要进程都完成为止。

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define getpch(type) (type *)malloc(sizeof(type))
  4. int t = 0;
  5. struct pcb {
  6. char name[10]; //进程名
  7. char state; //W/R/F
  8. int super; //优先数
  9. int ntime; //总运行时间
  10. int rtime; //已耗时
  11. int arrive_time; //到达时间
  12. struct pcb* link;
  13. } *ready = NULL, * p;
  14. typedef struct pcb PCB;
  15. int suanfa;
  16. void sort() { //优先集排序
  17. p->link = NULL;
  18. if (ready == NULL)
  19. ready = p;
  20. else {//分saunfa =1和saunfa =2两种情况 既分算法为
  21. //采用最高优先数优先的调度算法和先来先服务算法。
  22. if (p->super > ready->super&&suanfa==1) {
  23. p->link = ready;
  24. ready = p;
  25. }
  26. else {
  27. PCB* f = ready;
  28. while (1) {
  29. if (f->link == NULL) {
  30. f->link = p;
  31. return;
  32. }
  33. else if (p->super > f->link->super && suanfa == 1) {
  34. PCB* s = f->link;
  35. f->link = p;
  36. p->link = s;
  37. return;
  38. }
  39. else if (p->arrive_time < f->link->arrive_time&&suanfa == 2) {
  40. PCB* s = f->link;
  41. f->link = p;
  42. p->link = s;
  43. return;
  44. }
  45. f = f->link;
  46. }
  47. }
  48. }
  49. }
  50. void input() { //输入
  51. srand((unsigned)time(NULL));
  52. int n;
  53. cout << "请输入进程数目:";
  54. cin >> n;
  55. int time = 1;
  56. for (int i = 0; i < n; i++) {
  57. p = getpch(PCB);
  58. cout << "请分别输入进程名、进程优先数、运行时间:";
  59. cin >> p->name >> p->super >> p->ntime;
  60. p->state = 'W';
  61. p->rtime = 0;
  62. p->arrive_time = time;
  63. time++;
  64. sort();
  65. }
  66. }
  67. void disp(PCB* pr) { //输出模板
  68. cout << "进程名:" << pr->name << " ";
  69. cout << "进程状态:" << pr->state << " ";
  70. cout << "进程优先数:" << pr->super << " ";
  71. cout << "进程总运行时间:" << pr->ntime << " ";
  72. cout << "进程到达时间:" << pr->arrive_time << " ";
  73. cout << "进程已经耗时:" << pr->rtime << endl;
  74. }
  75. void check() { //输出
  76. cout << "-------------------" << " 正在运行中的进程 " << "------------------------------" << endl;
  77. disp(p);
  78. cout << "-------------------" << " 就绪队列中的进程 " << "------------------------------" << endl;
  79. PCB* pr = ready;
  80. while (pr != NULL) {
  81. disp(pr);
  82. pr = pr->link;
  83. }
  84. }
  85. void destroy() { /*建立进程撤消函数*/
  86. cout << "进程" << p->name << "运行完成,耗时" << p->ntime << "个CPU时间片" << endl;
  87. free(p);
  88. p = NULL;
  89. }
  90. void PSAandFCFS() { //主要运行函数
  91. p = ready;
  92. ready = ready->link;
  93. t++;
  94. cout << endl << "这是第" << t << "个CPU时间片" << endl;
  95. p->state = 'R';
  96. check();
  97. p->rtime++;
  98. if (p->ntime == p->rtime)
  99. destroy();
  100. else {
  101. p->super -= 1;
  102. p->state = 'W';
  103. sort();
  104. }
  105. if (p == NULL && ready == NULL)
  106. cout << "全部完成,共耗时" << t << "个CPU时间片" << endl;
  107. }
  108. int main() { /*主函数*/
  109. cout << "请输入你想使用的算法 输入 1 表示最高优先级优先算法 输入 2 表示先来先服务算法"<<endl;
  110. cin >> suanfa;
  111. input();
  112. while (p != NULL || ready != NULL)
  113. PSAandFCFS();
  114. return 0;
  115. }

五、实验结果与分析

1.测试数据及结果

第一组数据 选择算法2 既先来先运行算法 4组数据

第二组数据 采用算法1 既优先级优先算法 4组数据

1 4

a 1 1

b 3 2

c 2 3

d 10 1

第三组数据 采用算法1 既优先级优先算法 3组数据

1 3

a 3 2

b 8 1

c 1 3

标签: 算法 windows

本文转载自: https://blog.csdn.net/weixin_53138397/article/details/127415273
版权归原作者 大脚牛向前冲 所有, 如有侵权,请联系我们删除。

“操作系统:实验一:进程调度实验——最高优先数优先的调度算法以及先来先服务算法 源码”的评论:

还没有评论