用java实现操作系统进程调度问题 pcb rq bq

2024-02-07 11:18

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

用java实现操作系统进程调度问题
pcb.java   main.java readyqueue,java blocked.java

package Process;
/*
进程就绪队列:fifo,实现进程调度,处理器从就绪队列选择进程,
是进程从就绪态转为运行态,
数据结构:队列,(用链式存储实现)
只允许在头部删除,在尾部插入队列:另一种被限制的线性表
数据结构-逻辑结构:线性结构物理结构:顺序,链式队列:使用固定的一端插入元素,固定的一段删除元素只允许在表的前端(front)进行删除操作,只允许在表的后端(rear)进行插入操作队尾:进行插入操作的一段队售:进行删除操作的一端空队列:队列中没有任何的数据元素*/public class readyQueue<T> {private class Node{//节点n内部类,用于表示链式存储队列中的每个节点private T data;//节点的数据private Node next;//保存指向下一个节点的引用public Node(){}//构造函数,初始化public Node(T data,Node next){this.data=data;this.next=next;//构造函数,初始化}}/*就绪队列的属性*/private Node front;//保存就绪队列的头节点,即下一个会被处理机调度的进程,private Node rear;//保存就绪队列的伪结点,即就绪队列中新进来的进程都在这里插入private int size;//保存目前进程就绪队列中的进程数目/*就绪队列的方法*///1创建一个空的进程就绪队列,没有任何进程处于就绪状态public readyQueue(){//构造函数,初始化front=null;rear=null;size=0;}//2创建一个非空的就绪队列,以一个指定的进程来创建进程就绪队列public readyQueue(T element){front=new Node(element,null);rear=front;size=1;}//3返回目前进程就绪队列中进程的个数,,处于就绪状态进程的个数public int getSize(){return size;}//4返回进程就绪队列中的最后一个进程,即处于尾部的进程的数据public T getData(){return rear.data;}//5判断进程就绪队列是否为空public boolean isEmpty(){return size==0;}//6清空进程就绪队列public void clear(){front=null;rear=null;size=0;}//7将进程就绪队列中的所有进程的信息打印处理public String toString(){if(isEmpty())return "[]";else{StringBuilder sb=new StringBuilder("[");Node current=front;for(int i=0;i<size&¤t!=null;i++){sb.append(current.data.toString()+",");current=current.next;}sb.append("]");return  sb.toString();}}//8进程就绪队列从首部移除元素,即处于就绪队列头部的进程由就绪态转为运行态public T removeFromFront(){if(isEmpty()){throw new RuntimeException("就绪队列为空,无法从就绪队列中移除就绪进程,");}else{Node del=front;front=del.next;T value=del.data;del=null;size--;return value;}}//9向就绪队列的尾部插入进程,这些进程可能是timeout的进程,也可能是♥调度来的进程public void addAtRear(T element){if(front==null){front=new Node(element,null);rear=front;}else{Node newNode=new Node(element,null);rear.next=newNode;rear=newNode;}size++;}
}

package Process;
/*
2018/05/23:pcb进程控制块类,操作系统利用进程控制块,实现对进程的调度*/
public class pcb {private int id;//进程标识符private int status;//进程状态(1表示运行态,2表示就绪态,3表示阻塞态)//保护进程现场信息private int ax,bx,cx,dx;//通用寄存器ax,bx,cx,dx的内容private int pc;//程序计数器内容private int psw;//程序状态字内容private int next;//下一个pcb的位置private int execute_time;//进程执行总共需要用的时间private int arrival_time;//进程目前已经占用处理器的时间public int getExecute_time() {return execute_time;}public void setExecute_time(int execute_time) {this.execute_time = execute_time;}public int getArrival_time() {return arrival_time;}public void setArrival_time(int arrival_time) {this.arrival_time = arrival_time;}public int getId() {return id;}public void setId(int id) {this.id = id;}public int getStatus() {return status;}public void setStatus(int status) {this.status = status;}public int getAx() {return ax;}public void setAx(int ax) {this.ax = ax;}public int getBx() {return bx;}public void setBx(int bx) {this.bx = bx;}public int getCx() {return cx;}public void setCx(int cx) {this.cx = cx;}public int getDx() {return dx;}public void setDx(int dx) {this.dx = dx;}public int getPc() {return pc;}public void setPc(int pc) {this.pc = pc;}public int getPsw() {return psw;}public void setPsw(int psw) {this.psw = psw;}public int getNext() {return next;}public void setNext(int next) {this.next = next;}public String toString(){return "进程信息"+"id:"+id+"  status:"+status+"  ax:"+ax+"  bx:"+bx+"  cx:"+cx+"  dx:"+dx+"  pc:"+pc+"  psw:"+psw+"  next:"+next+"  execute_time:"+execute_time+"  arrival_time:"+arrival_time;}
}

package Process;
import java.util.Scanner;
/*
主函数,实现实验功能*/
public class Main {//定义系统参数public static final int pronum=3;//系统中进程总数,,进程总数不固定,任意,就绪队列阻塞队列用链表实现,依次无所谓public static final int time=50;//时间片大小//进程创建函数public boolean create(){return true;}//进程调度函数public boolean scheduling(){return true;}//主进程,系统初始化public static void main(String[] args){//创建进程就绪对列readyQueue<pcb> rq=new readyQueue<pcb>();//创建进程阻塞队列blockedQueue<pcb> bq=new blockedQueue<pcb>();/*执行流程1录入进程,为进程保存pcb信息*/Scanner sc=new Scanner(System.in);System.out.println("进程标识信息:请输入进程编号(进程标识符),最多可以创建10个进程");for(int i=0;i<pronum;i++){pcb p=new pcb();System.out.println("请输入数字零进入系统:");int x=sc.nextInt();System.out.println("请按照相应提示输入进程现场信息:");System.out.println("请输入进程标识符id的信息");int id=sc.nextInt();p.setId(id);//进程状态(1表示运行态,2表示就绪态,3表示阻塞态)int status=2;p.setStatus(status);System.out.println("请输入通用寄存器ax的内容");int ax=sc.nextInt();p.setAx(ax);System.out.println("请输入通用寄存器bx的内容");int bx=sc.nextInt();p.setBx(bx);System.out.println("请输入通用寄存器cx的内容");int cx=sc.nextInt();p.setCx(cx);System.out.println("请输入通用寄存器dx的内容");int dx=sc.nextInt();p.setDx(dx);System.out.println("请输入程序计数器pc的内容");int pc=sc.nextInt();p.setPc(pc);System.out.println("请输入程序状态字psw的内容");int psw=sc.nextInt();p.setPsw(psw);System.out.println("请输入下一个pcb的位置信息");int next=sc.nextInt();p.setNext(next);System.out.println("请输入进程执行所需的总时间");int execute_time=sc.nextInt();p.setExecute_time(execute_time);// System.out.println(p);System.out.println("已经成功为进程建立了进程控制块");System.out.println(p.toString());System.out.println("该进程已进入就绪队列");rq.addAtRear(p);System.out.println("查看就绪队列中现有进程"+rq.toString());}System.out.println("给进程分配cpu");pcb pz=rq.removeFromFront();pz.setArrival_time(pz.getArrival_time()+time);pz.setStatus(3);bq.addAtRear(pz);while(!rq.isEmpty()){pcb p0=rq.removeFromFront();p0.setArrival_time(p0.getArrival_time()+time);p0.setStatus(1);if(p0.getExecute_time()>=p0.getArrival_time()){p0.setStatus(2);rq.addAtRear(p0);}System.out.println("查看就绪队列中现有进程"+rq.toString());}System.out.println("就绪队列中进程执行完毕");System.out.println("查看阻塞队列中现有进程"+bq.toString());System.out.println("将进程从阻塞队列中移除,转入相应的就绪队列中");pcb p0=bq.removeFromFront();System.out.println("查看阻塞队列中现有进程"+bq.toString());p0.setStatus(2);rq.addAtRear(p0);System.out.println("查看就绪队列中现有进程"+rq.toString());while(!rq.isEmpty()){pcb px=rq.removeFromFront();px.setArrival_time(px.getArrival_time()+time);px.setStatus(1);if(px.getExecute_time()>=px.getArrival_time()){px.setStatus(2);rq.addAtRear(px);}System.out.println("查看就绪队列中现有进程"+rq.toString());}System.out.println("查看就绪队列中现有进程"+rq.toString());System.out.println("所有进程执行完毕");}
}

package Process;
/*
进程就绪队列:fifo,实现进程调度,处理器从就绪队列选择进程,
是进程从就绪态转为运行态,
数据结构:队列,(用链式存储实现)
只允许在头部删除,在尾部插入队列:另一种被限制的线性表
数据结构-逻辑结构:线性结构物理结构:顺序,链式队列:使用固定的一端插入元素,固定的一段删除元素只允许在表的前端(front)进行删除操作,只允许在表的后端(rear)进行插入操作队尾:进行插入操作的一段队售:进行删除操作的一端空队列:队列中没有任何的数据元素*/public class blockedQueue<T> {private class Node{//节点n内部类,用于表示链式存储队列中的每个节点private T data;//节点的数据private Node next;//保存指向下一个节点的引用public Node(){}//构造函数,初始化public Node(T data,Node next){this.data=data;this.next=next;//构造函数,初始化}}/*就绪队列的属性*/private Node front;//保存就绪队列的头节点,即下一个会被处理机调度的进程,private Node rear;//保存就绪队列的伪结点,即就绪队列中新进来的进程都在这里插入private int size;//保存目前进程就绪队列中的进程数目/*就绪队列的方法*///1创建一个空的进程就绪队列,没有任何进程处于就绪状态public blockedQueue(){//构造函数,初始化front=null;rear=null;size=0;}//2创建一个非空的就绪队列,以一个指定的进程来创建进程就绪队列public blockedQueue(T element){front=new Node(element,null);rear=front;size=1;}//3返回目前进程就绪队列中进程的个数,,处于就绪状态进程的个数public int getSize(){return size;}//4返回进程就绪队列中的最后一个进程,即处于尾部的进程的数据public T getData(){return rear.data;}//5判断进程就绪队列是否为空public boolean isEmpty(){return size==0;}//6清空进程就绪队列public void clear(){front=null;rear=null;size=0;}//7将进程就绪队列中的所有进程的信息打印处理public String toString(){if(isEmpty())return "[]";else{StringBuilder sb=new StringBuilder("[");Node current=front;for(int i=0;i<size&¤t!=null;i++){sb.append(current.data.toString()+",");current=current.next;}sb.append("]");return  sb.toString();}}//8进程就绪队列从首部移除元素,即处于就绪队列头部的进程由就绪态转为运行态public T removeFromFront(){if(isEmpty()){throw new RuntimeException("就绪队列为空,无法从就绪队列中移除就绪进程,");}else{Node del=front;front=del.next;T value=del.data;del=null;size--;return value;}}//9向就绪队列的尾部插入进程,这些进程可能是timeout的进程,也可能是♥调度来的进程public void addAtRear(T element){if(front==null){front=new Node(element,null);rear=front;}else{Node newNode=new Node(element,null);rear.next=newNode;rear=newNode;}size++;}
}

这篇关于用java实现操作系统进程调度问题 pcb rq bq的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创