进程管理系统

本文档详述了一个进程管理系统的设计,涵盖了FCFS(先来先服务)、SPF(最短处理时间优先)和RR(时间片轮转)三种调度算法。系统包含至少5个进程,并强调了PCB(进程控制块)的定义。通过示例代码,阐述了如何体现进程的动态申请和调度过程,同时要求输出包括进程调度序列、进入系统时间、运行时间、完成时间、周转时间和带权周转时间在内的关键信息,以展示各种算法的特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

要求:

  1. 设计一个完整的进程调度系统,至少包含三种常用的算法(FCFS、SPF、静态优先权、响应比、时间片轮转),系统中至少包含5个进程,并且能够体现进程的动态申请;
  2. 定义PCB;
  3. 结果要能够显示出进程的调度序列及进入系统的时间、运行时间、完成时间、周转时间、带权周转时间、优先权等必要信息;
  4. 设计的输入数据要能体现算法的思想

Code:

PCB:

package pms_os.entity;

public class PCB {
   
    private String Name;  //进程名称
    private boolean has_serviced;  //标记是否执行
    private int arrive_Time;  //进程到达时间
    private int service_Time;  //进程服务时间
    private int serviced_Time;  //进程已服务时间
    private int start_Time;  //进程服务开始时间
    private int end_Time;  //进程服务结束时间
    private double around_Time;  //进程周转时间
    private double around_Right_Time;  //带权周转时间

    //重新toString方法,便于输出
    @Override
    public String toString() {
   
        return "进程名称:" + Name +
                ", 到达时间:" + arrive_Time +
                ", 服务时间:" + service_Time +
                ", 开始执行时间:" + start_Time +
                ", 完成时间:" + end_Time +
                ", 周转时间:" + around_Time +
                ", 带权周转时间:" + around_Right_Time;
    }

    //各属性的set, get方法
    public String getName() {
   
        return Name;
    }

    public void setName(String name) {
   
        Name = name;
    }

    public boolean ishas_serviced() {
   
        return has_serviced;
    }

    public void sethas_serviced(boolean has_serviced) {
   
        this.has_serviced = has_serviced;
    }

    public int getArrive_Time() {
   
        return arrive_Time;
    }

    public void setArrive_Time(int arrive_Time) {
   
        this.arrive_Time = arrive_Time;
    }

    public int getService_Time() {
   
        return service_Time;
    }

    public void setService_Time(int service_Time) {
   
        this.service_Time = service_Time;
    }

    public int getServiced_Time() {
   
        return serviced_Time;
    }

    public void setServiced_Time(int serviced_Time) {
   
        this.serviced_Time = serviced_Time;
    }

    public int getStart_Time() {
   
        return start_Time;
    }

    public void setStart_Time(int start_Time) {
   
        this.start_Time = start_Time;
    }

    public int getEnd_Time() {
   
        return end_Time;
    }

    public void setEnd_Time(int end_Time) {
   
        this.end_Time = end_Time;
    }

    public double getAround_Time() {
   
        return around_Time;
    }

    public void setAround_Time(double around_Time) {
   
        this.around_Time = around_Time;
    }

    public double getAround_Right_Time() {
   
        return around_Right_Time;
    }

    public void setAround_Right_Time(double around_Right_Time) {
   
        this.around_Right_Time = around_Right_Time;
    }
}

Main:

package pms_os;

import pms_os.entity.PCB;
import pms_os.service.*;

import java.util.ArrayList;
import java.util.Scanner;

public class Main {
   
    static ArrayList<PCB> p_list = new ArrayList<PCB>();  // 用于存储进程的列表
    static Scanner input = new Scanner(System.in);  // 用于键盘输入

    // 主程序
    public static void main(String[] args) {
   
        // 创建Main对象便于调用方法
        Main os_main = new Main();

        // 提示信息
        System.out.println("欢迎使用进程管理系统,请按照提示输入进程信息。");

        boolean is_exit = false;  // 标记是否选择退出
        boolean is_firsr = true;  // 标记是第一次运行
        boolean is_restar = false;  // 标记是否重新输入数据

        while (true) {
   
            if (is_firsr || is_restar) {
     // 若为第一次或重新输入数据
                p_list.clear();  // 清空列表
                os_main.Input();  // 调用Input方法,获取数据
            }
            while (true) {
   
                is_firsr = false;  // 第一次更改为false
                is_restar = false;  // 重新输入初始化为false

                os_main.show();  // 调用方法提示系统信息
                int choose = Integer.parseInt(input.nextLine());  // 输入选择执行的选项

                ArrayList<PCB> list1 <
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值