操作系统 - 进程调度的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

相关文章

JAVA保证HashMap线程安全的几种方式

《JAVA保证HashMap线程安全的几种方式》HashMap是线程不安全的,这意味着如果多个线程并发地访问和修改同一个HashMap实例,可能会导致数据不一致和其他线程安全问题,本文主要介绍了JAV... 目录1. 使用 Collections.synchronizedMap2. 使用 Concurren

Java Response返回值的最佳处理方案

《JavaResponse返回值的最佳处理方案》在开发Web应用程序时,我们经常需要通过HTTP请求从服务器获取响应数据,这些数据可以是JSON、XML、甚至是文件,本篇文章将详细解析Java中处理... 目录摘要概述核心问题:关键技术点:源码解析示例 1:使用HttpURLConnection获取Resp

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py

Python利用ElementTree实现快速解析XML文件

《Python利用ElementTree实现快速解析XML文件》ElementTree是Python标准库的一部分,而且是Python标准库中用于解析和操作XML数据的模块,下面小编就来和大家详细讲讲... 目录一、XML文件解析到底有多重要二、ElementTree快速入门1. 加载XML的两种方式2.

Python如何精准判断某个进程是否在运行

《Python如何精准判断某个进程是否在运行》这篇文章主要为大家详细介绍了Python如何精准判断某个进程是否在运行,本文为大家整理了3种方法并进行了对比,有需要的小伙伴可以跟随小编一起学习一下... 目录一、为什么需要判断进程是否存在二、方法1:用psutil库(推荐)三、方法2:用os.system调用

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Java中Switch Case多个条件处理方法举例

《Java中SwitchCase多个条件处理方法举例》Java中switch语句用于根据变量值执行不同代码块,适用于多个条件的处理,:本文主要介绍Java中SwitchCase多个条件处理的相... 目录前言基本语法处理多个条件示例1:合并相同代码的多个case示例2:通过字符串合并多个case进阶用法使用