操作系统 - 进程调度的Java实现(FCFS,RR,HPF)

2023-10-09 17:10

本文主要是介绍操作系统 - 进程调度的Java实现(FCFS,RR,HPF),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 实验要求
  • 具体思路
  • 调度算法
  • 代码实现
    • 主函数和进程类
    • 最高优先数优先的调度算法
    • 时间片轮转算法
    • 先来先服务调度算法

实验要求

用高级语言编写和调试一个进程调度程序,以加深对进程的概念及进程调度算法的理解。

编写并调试一个模拟的进程调度程序,采用最高优先数优先调度算法对五个进程
进行调度。 “最高优先数优先”调度算法的基本思想是把 CPU 分配给就绪队列中优先数最高的进程。

  1. 静态优先数是在创建进程时确定的,并在整个进程运行期间不再改变。
  2. 动态优先数是指进程的优先数在创建进程时可以给定一个初始值,并且可以按一定原则修改优先数。例如:在进程获得一次 CPU 后就将其优先数减少 1,或者,进程等待的时间超过某一时限时增加其优先数的值,等等。

编写并调试一个模拟的进程调度程序,采用轮转法调度算法对五个进程进行调度。

  1. 轮转法可以是简单轮转法、可变时间片轮转法,或多队列轮转法。
  2. 简单轮转法的基本思想是:所有就绪进程按 FCFS 排成一个队列,总是把处理机分配给队首的进程,各进程占用 CPU 的时间片相同。如果运行进程用完它的时间片后还为完成,就把它送回到就绪队列的末尾,把处理机重新分配给队首的进程,直至所有的进程运行完毕。

具体思路

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

进程调度算法:采用最高优先数优先的调度算法(即把处理机分配给优先数最高的进程)和先来先服务算法。

每个进程有一个进程控制块( PCB)表示。进程控制块可以包含如下信息:进程名、优先数、到达时间、需要运行时间、已用 CPU 时间、进程状态等等。进程的优先数及需要的运行时间可以事先人为地指定(也可以由随机数产生),进程的到达时间为进程输入的时间,进程的运行时间以时间片为单位进行计算。

每个进程的状态可以是就绪 W(Wait)、运行 R(Run)、或完成 F(Finish)三种状态之一(这是编程用到的三个模拟状态,并非进程的三基态)。就绪进程获得 CPU 后都只能运行一个时间片,用已占用 CPU 时间加 1 来表示。如果运行一个时间片后,进程的已占用 CPU 时间已达到所需要的运行时间,则撤消该进程,如果运行一个时间片后进程的已占用 CPU 时间还未达所需要的运行时间,也就是进程还需要继续运行,此时应将进程的优先数减 1(即降低一级),然后把它插入就绪队列等待 CPU。

每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的 PCB,以便进行检查。重复以上过程,直到所要进程都完成为止。
流程图如下
在这里插入图片描述

调度算法

https://blog.csdn.net/luyafei_89430/article/details/12971171

代码实现

在这里插入图片描述
MyProcess类为进程的基本信息类。
Main类中放了主函数。
FCFS类封装了先来先服务算法。
HPF封装了高优先级优先调度算法。
RR封装了时间片轮转算法。

主函数和进程类

MyProcess类存储进程的基本信息,Main类放主函数。

main.java

package ProcessScheduling; 
import java.io.File;
import java.io.FileNotFoundException;
import java.util.ArrayList;
import java.util.Scanner;public class Main {public static void main(String[] args) throws FileNotFoundException {//输入数据File file = new File("C:\\Users\\Administrator\\Desktop\\codes\\in.txt");Scanner scanner = new Scanner(file);
//		Scanner scanner = new Scanner(System.in);System.out.println("请输入进程总数");Integer n = scanner.nextInt(); ArrayList<MyProcess> processList = new ArrayList<>();for(int i = 0;i<n;i++) {System.out.println("请输入"+(i+1)+"号进程的进程名、优先数、到达时间、需要运行时间(空格隔开):");String name = scanner.next();Integer priority = scanner.nextInt();Integer arrivalTime = scanner.nextInt();Integer needTime = scanner.nextInt();processList.add(new MyProcess(name,priority,arrivalTime,needTime));}
//		for(MyProcess i : processList) {
//			System.out.println(i);
//		}System.out.println("请输入调度算法:");n = scanner.nextInt(); if(n == 1) {FCFS fcfs = new FCFS(processList);fcfs.dispatch();}else if(n==2){HPF hpf = new HPF(processList);hpf.dispatch();}else if(n==3){RR rr = new RR(processList);rr.dispatch();}}
}MyProcess.java 
```css
package ProcessScheduling;public class MyProcess {//进程名、优先数、到达时间、需要运行时间、已用 CPU 时间、进程状态private String name;private int priority;private int arrivalTime;private int needTime;

这篇关于操作系统 - 进程调度的Java实现(FCFS,RR,HPF)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/174318

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu