文档详情

操作系统 实验二 主存分配与回收.doc

发布:2018-04-17约1.87万字共35页下载文档
文本预览下载声明
实验二 主存分配与回收 一、实验内容 主存储器空间的分配和回收 二、实验目的 帮助了解在不同的存储管理方式下,应怎样实现主存空间的分配和回收。 三、实验题目 在可变分区管理方式下,采用最先适应算法实现主存空间的分配和回收。 四、实验要求 1、自行假设主存空间大小,预设操作系统所占大小并构造未分分区表; 表目内容:起址、长度、状态(未分/空表目) 2、结合实验一,PCB增加为: {PID,要求运行时间,优先权,状态,所需主存大小,主存起始位置,PCB指针} 3、采用最先适应算法分配主存空间; 4、进程完成后,回收主存,并与相邻空闲分区合并。 五、实验源码 /** * @(#)MemoryAllocationReclaim.java * * * @author Liang Jiabin * @version 1.00 2010/11/28 */ import java.awt.*; import javax.swing.*; import javax.swing.table.DefaultTableModel; import java.awt.event.ActionListener; import java.awt.event.ActionEvent; import java.util.Vector; public class MemoryAllocationReclaim extends Thread { private JFrame frame; private JScrollPane reserveSp, readySp, waitingSp, finishSp, unAllocationSp; private JTable reserveT,readyT,waitingT,finishT, unAllocationT; private DefaultTableModel reserveTm, readyTm, waitingTm, finishTm, unAllocationTm; private JLabel reserveLbl, readyLbl, CPULbl, waitingLbl, finishLbl; private JTextField CPUTf; private JLabel needTimeLbl, priorityLbl, unAllocationLbl, sizeLbl; private JComboBox needTimeCb, priorityCb, sizeCb; private JButton newBtn, suspendBtn, unsuspendBtn, exitBtn; private JLabel rToRLbl, rToCPULbl, CPUToRLbl, CPUToWLbl, wToRLbl; private JLabel CPUToFLbl, warningLbl; private String[] unAllocationColumnNames = {起址, 长度, 状态}; //未分分区表列名 private String[] columnNames0 = {进程名, 要求时间, 优先权, 主存大小}; //后备队列列名 private String[] columnNames = {进程名, 要求时间, 优先权,起始位置,主存大小}; //就绪、挂起与完成队列列名 private String[][] data0 = new String[0][4];//后备对列 private String[][] data1 = new String[5][5];//就绪队列 private String[][] data2 = new String[0][5];//挂起与完成队列 private String[][] data3 = new String[0][3];//未分分区表 /*全局变量*/ private int number = 1; //进程名序号 private int readyCount = 0; //就绪队列中的进程数 private int waitingReadyIndex = 0; //要接挂的进程在挂起队列的下标 private String[] waitingReady = {, , , , }; //要解挂的进程内容 private String[] CPUProcess = {, 0, 0, , }; //CPU中的进程 private int unAllo
显示全部
相似文档