【进程调度】基于优先级的轮转调度C++实现算法

一、简介

1.1 背景

在计算机科学领域,进程调度是操作系统中一个关键的组成部分,它负责协调系统中各个进程的执行顺序,以最大程度地提高系统资源利用率。在这篇博客中,将深入探讨基于优先级的轮转调度算法,该算法结合了进程的优先级时间片轮转的思想,以实现高效的任务执行。
在这里插入图片描述

1.2 目的

本文的主要目的是解释和分析一个使用C++编写的简单进程调度程序。将详细介绍程序的结构和实现细节,同时提供示例以帮助读者理解基于优先级的轮转调度算法的工作原理。

1.3 代码概览

程序需要使用一个结构体 content 来表示进程,包括进程名、优先级、到达时间、需要时间、已用时间和进程状态等信息。主要功能包括增加进程、打印结果以及实现基于优先级的轮转调度。以下是进程调度程序的框架:
程序框架 { m a i n 主函数:用于循环菜单操作 m a r k 主菜单:提示用户包括输入时间片、打印结果等 p r t 函数:进程调度算法以及输出进程调度的结果 a d d 函数:增加进程信息 c o n t e n t 结构体:进程名、优先级、到达时间、需要时间、已用时间和进程状态等信息 程序框架\begin{cases} main主函数:用于循环菜单操作\\mark主菜单:提示用户包括输入时间片、打印结果等\\prt函数:进程调度算法以及输出进程调度的结果\\add函数:增加进程信息\\content结构体:进程名、优先级、到达时间、需要时间、已用时间和进程状态等信息 \end{cases} 程序框架 main主函数:用于循环菜单操作mark主菜单:提示用户包括输入时间片、打印结果等prt函数:进程调度算法以及输出进程调度的结果add函数:增加进程信息content结构体:进程名、优先级、到达时间、需要时间、已用时间和进程状态等信息

二、进程调度算法概述

2.1 优先级调度算法

优先级调度算法是一种常见的进程调度策略,它根据进程的优先级来确定执行顺序。在我们的程序中,每个进程都被赋予一个优先级 (f),并根据该优先级进行排序。较高优先级的进程将在较低优先级的进程之前执行。
在这里插入图片描述

2.2 轮转调度算法

轮转调度算法引入了时间片的概念,即每个进程被分配的执行时间。在我们的实现中,用户可以输入时间片的大小,这将影响每个进程的运行时间。当一个进程用完它的时间片后,调度程序将切换到下一个就绪队列中的进程,以此类推。
在这里插入图片描述

三、代码详解

3.1 结构体定义

在程序中,使用一个名为 content 的结构体来表示每个进程的信息。这个结构体包含进程名 (name)、优先级 (f)、到达时间 (arrtime)、所需时间 (needtime)、已用时间 (gettime) 以及进程状态 (process)。

struct content
{string name;     // 进程名int f;           // 优先级int arrtime;     // 到达时间int needtime;    // 所需时间int gettime;     // 已用时间string process;  // 进程状态
};

这个结构体的定义来组织和存储每个进程的相关信息。

3.2 主菜单函数 (mark)

主菜单函数 mark 用于引导用户进行操作选择。用户可以选择增加进程、打印进程状态,或结束任务。该函数返回用户的选择。

int mark()
{int pd;cout << "增加进程并调度进程,请按1\n打印进程,请按2\n任务结束,请按0" << endl;cin >> pd;if (pd < 0 || pd > 2){return mark();}return pd;
}

3.3 增加进程函数 (add)

增加进程函数 add 用于向进程数组中添加新的进程。用户需要输入进程的名称、优先级以及所需时间。这个函数返回一个标志,指示是否继续增加进程。

int add(struct content a[], int i)
{char pd;cout << "请输入进程名:";cin >> a[i].name;cout << "请输入进程的优先级:";cin >> a[i].f;cout << "请输入进程需要的时间:";cin >> a[i].needtime;a[i].arrtime = i;        // 设置到达时间a[i].gettime = 0;        // 初始化已用时间a[i].process = 'W';      // 初始化进程状态(等)cout << "还要继续增加进程吗,是(Y)否(N)";cin >> pd;if (pd == 'N')return 0;return 1;
}

函数允许用户连续添加多个进程,直到用户选择停止。

3.4 打印结果函数 (prt)

打印结果函数 prt 负责对进程进行排序,并根据优先级和到达时间打印进程状态。该函数还包括递归调用以模拟进程的运行。

void prt(struct content a[], int n, int time)
{// (排序和打印结果的实现)int i,j,pd=0;//排序for(i=0;i<=n-1;i++){for(j=0;j<=n-i-1;j++){if(a[j].f<a[j+1].f||(a[j].f==a[j+1].f&&a[j].arrtime>a[j+1].arrtime))//先根据优先级,后根据到达时间判断{struct content temp;temp=a[j];a[j]=a[j+1];a[j+1]=temp;}}}a[0].process='R';//改变第一个进程的状态(运行)for(i=0;i<=n;i++){if(a[i].gettime<a[i].needtime){pd=1;break;}}if(pd==0){a[0].process='F';//修改最后进程完成状态}	cout<<"进程名  优先级  到达时间  需要时间  已用时间  进程状态"<<endl;for(i=0;i<=n;i++){cout<<a[i].name<<"\t"<<a[i].f<<"\t"<<a[i].arrtime<<"\t  "<<a[i].needtime<<"\t    "<<a[i].gettime<<"\t      "<<a[i].process<<endl;}if (pd == 0){return; // 退出递归}// 修改数据a[0].f -= 1;a[0].gettime += time;a[0].process = 'W';if (a[0].gettime >= a[0].needtime){a[0].f = -1000;a[0].gettime = a[0].needtime;a[0].process = 'F';}prt(a, n, time); // 递归打印
}

这个函数通过递归调用自身,模拟了进程的调度和执行过程。在打印结果时,它显示了每个进程的详细信息,包括进程名、优先级、到达时间、需要时间、已用时间和进程状态。

3.5 主函数(main)

int main()
{int time;     // 时间片大小int i = -1;    // 记录进程个数和到达时间struct content a[10];cout << "请输入时间片大小:";cin >> time;while (1){int pd = mark();  // 主菜单判断if (pd == 0)break;  // 退出if (pd == 1){while (1){i++;int pd = add(a, i);if (pd == 0)break;  // 增加进程完毕,退出}}if (pd == 2){prt(a, i, time);continue;}prt(a, i, time);}
}

3.6 运行示例

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/621114.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue3-customRef的使用

读取数据前&#xff0c;需要先track&#xff08;&#xff09; 告诉Vue数据msg很重要&#xff0c;你要对msg进行持续关注&#xff0c;一旦msg变化就去更新 修改数据后&#xff0c;需要trigger&#xff08;&#xff09;收尾 通知Vue一下数据msg变化了 自定义ref如何防抖 hooks中…

UniApp调试支付宝沙箱(安卓)

先看下这里完整的交互的图&#xff1a;小程序文档 - 支付宝文档中心 一、打包 不管怎样&#xff0c;先打个包先。可以直接使用云端证书、云端打包&#xff0c;只需要指定包名即可。 二、在支付宝开放平台创建应用 这个参考官方的过程就可以了&#xff0c;只要有刚才打的包&…

Fastadmin上传图片服务端压缩图片,实测13.45M压缩为29.91K

先前条件&#xff1a;第一步安装compose&#xff0c;已安装忽略。 先上截图看效果 一、在fastadmin的根目录里面输入命令安装think-image composer require topthink/think-image二、找到公共上传类&#xff0c;application/common/library/Upload.php&#xff0c;在最下面…

Redis系列之使用Lua脚本

什么是lua脚本&#xff1f; lua语言是一个轻量级的脚本语言&#xff0c;可以嵌入其他语言中使用&#xff0c;调用宿主语言的功能。lua语法简单&#xff0c;小巧&#xff0c;源码一共才200多K&#xff0c;本身不会有太强的功能&#xff0c;很多的语言也支持lua语言&#xff0c;…

TensorRT(C++)基础代码解析

TensorRT(C)基础代码解析 文章目录 TensorRT(C)基础代码解析前言一、TensorRT工作流程二、C API2.1 构建阶段2.1.1 创建builder2.1.2 创建网络定义2.1.3 定义网络结构2.1.4 定义网络输入输出2.1.5 配置参数2.1.6 生成Engine2.1.7 保存为模型文件2.1.8 释放资源 2.2 运行期2.2.1…

【elastic search】详解elastic search集群

目录 1.与集群有关的一些概念 2.集群搭建 3.集群搭建 4.kibana链接集群 5.选举流程 6.请求流程 7.master的作用 1.与集群有关的一些概念 数据分片&#xff1a; 数据分片&#xff08;shard&#xff09;&#xff0c;单台服务器的存储容量是有限的&#xff0c;把一份数据…

git提交记录全部删除

目录 问题描述 解决方案 结果 问题描述 新复制的项目具有特比多的提交记录我想给他清除&#xff0c;因为不清楚过多历史也就导致包特别大下载和提交等方面都不是很快 解决方案 查看代码clone网址&#xff1b; 打开远程仓库&#xff0c;选择要去除历史记代码分支&#xff08…

xtu oj 1475 Repeat One

题目描述 求由最小的一个N&#xff0c;N个数码1组成的数能被M整除&#xff1f; 比如M3时&#xff0c;111能被3整除。M2时&#xff0c;则不存在这样的N。 输入 第一行是一个整数K(K≤1,000),表示样例的个数。 以后每行一个整数M(1≤M≤1,000,000) 输出 每行输出一个样例的结…

opencv仿射变换

#include <opencv2/opencv.hpp> /* 功能&#xff1a;对一系列坐标点进行平移仿射变换 参数&#xff1a; srcPoints:输入点坐标 dstPoints:变换后的点坐标 x:x方向平移的距离 y:y方向平移的距离 */ void tranlatePoints(std::vector<cv::Point2f>& srcPoints, …

低代码助力制造业数智转型,激发创新力迎接工业 4.0

随着科技的不断进步&#xff0c;我们迈入了一个崭新的工业时代——工业4.0。这场工业革命不仅颠覆了制造业的传统形象&#xff0c;还为全球生产方式带来了前所未有的变革。 在这一过程中&#xff0c;制造业数字化转型逐渐成为主旋律&#xff0c;而低代码技术在这其中发挥着重要…

近红外光谱分析技术与基于深度学习的化学计量学方法

郁磊【副教授】&#xff1a;主要从事AI人工智能与大数据分析等相关研究&#xff0c;长期致力于人工智能与近红外生物医学工程等领域融合&#xff0c;主持并完成多项科研课题。著有《神经网络43个案例分析》等书籍。 // 讲座内容 1、近红外光谱基本理论、近红外光谱仪基本原理…

openssl3.2 - 官方demo学习 - digest - EVP_MD_stdin.c

文章目录 openssl3.2 - 官方demo学习 - digest - EVP_MD_stdin.c概述笔记END openssl3.2 - 官方demo学习 - digest - EVP_MD_stdin.c 概述 使用 SHA3-512 对stdin输入做摘要, 并输出摘要值. 笔记 /*! \file EVP_MD_stdin.c \note openssl3.2 - 官方demo学习 - digest - EVP…

python爬虫-代理ip理解

目录 1、为什么使用代理IP 2、代理IP 3、IP池 4、代理分类&#xff1a; 5、python中使用代理IP 6、如何找可以使用的代理IP 7、拿到IP后&#xff0c;测试IP的有效性 8、扩展理解正向代理和反向代理 1、为什么使用代理IP 就是为了防止ip被封禁&#xff0c;提高爬虫的效…

【Proteus仿真】【Arduino单片机】智能窗户设计

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真Arduino单片机控制器&#xff0c;使用蜂鸣器模块、LCD1602显示模块、雨滴传感器、风速传感器、人体红外模块、ADC模块、按键模块、28BYJ48步进电机 模块、DS18B20温度传感器等。 …

2023年北邮渣硕的暑期秋招总结

背景 实验室一般是在研究生二年级的时候会放实习&#xff0c;在以后的日子就是自己完成毕业工作要求&#xff0c;基本上不再涉及实验室的活了&#xff0c;目前是一月份也是开始准备暑期实习的好时间。实验室每年这个时候都会有学长学姐组织暑期实习经验分享&#xff0c;本着不…

外国入境的免签国家以及中外互免(普通护照*、普通公务护照)

2024.1.11起&#xff0c;外籍人员在北京首都、北京大兴、上海浦东、杭州萧山、厦门高崎、广州白云、深圳宝安、成都天府、西安咸阳9个国际机场&#xff0c;推行24小时直接过境旅客免办边检手续。对于持24小时内国际联程机票&#xff0c;经上述任一机场过境前往第三国或地区的出…

Python dataframe取单元值

取dataframe某行某列所指的单元值 代码准备&#xff1a; 环境平台&#xff1a;Python 3.7.1 -IDLE Shell >>> import pandas as pd >>> df pd.DataFrame({Name: [Tom, Jim, Lily], Age: [20, 18, 22], Gender: [Male, Male, Female]})注&#xff1a;部分参…

高防dns服务器租用有哪些应用场景?-速盾cdn

高防DNS服务器租用可以应用于以下场景&#xff1a; 网站安全防护&#xff1a;高防DNS服务器可以提供强大的防御能力&#xff0c;抵御DDoS攻击、DNS劫持、泛洪攻击等威胁&#xff0c;保证网站的稳定运行和安全性。 网络游戏&#xff1a;网络游戏通常面临大量用户同时访问和数据…

C#中对浮点数NaN,PositiveInfinity,NegativeInfinity的特殊处理

NAN NAN 整体意思为Not a Number 不是一个数&#xff0c; NaN&#xff08;Not a Number&#xff0c;非数&#xff09;是计算机科学中数值数据类型的一类值&#xff0c;表示未定义或不可表示的值。常在浮点数运算中使用。首次引入NaN的是1985年的IEEE 754浮点数标准。 EEE 75…

论文阅读 Self-Supervised Burst Super-Resolution

这是一篇 ICCV 2023 的文章&#xff0c;主要介绍的是用自监督的方式进行多帧超分的学习 Abstract 这篇文章介绍了一种基于自监督的学习方式来进行多帧超分的任务&#xff0c;这种方法只需要原始的带噪的低分辨率的图。它不需要利用模拟退化的方法来构造数据&#xff0c;而且模…