操作系统-固定分区存储管理

一、实验目的

通过编写和调试存储管理的模拟程序以加深对存储管理固定分区存储管理方案的理解。实现固定分区存储管理的分配、去配。

二、实验内容

设计一个固定分区存储管理方案。并编写模拟程序实现之。以下是一个固定分区的内存分配表

三、实验环境

Eclipse win10

四、实验步骤

import java.util.Scanner;


class FQ{
	public  String no;
	public  String qs;
	public  int cd;
	public  String zybz;
	public FQ(String no, String qs, int cd, String zybz) {
		super();
		this.no = no;
		this.qs = qs;
		this.cd = cd;
		this.zybz = zybz;
	}
}


public class Mainclass {
	public static void main(String[] args) {
		FQ[] fq = new FQ[6];
		fq[0]=new FQ("1","08k",8,"0");
		fq[1]=new FQ("2","16k",16,"job1");
		fq[2]=new FQ("3","32k",16,"0");
		fq[3]=new FQ("4","48k",16,"0");
		fq[4]=new FQ("5","64k",32,"job2");
		fq[5]=new FQ("6","96k",32,"0");
		System.out.println("分区号 "+"起始地址"+"长度  "+"占用标志");
		for(int i=0;i<fq.length;i++){
			if(fq[i].cd<=10){
				System.out.println(fq[i].no+"    "+fq[i].qs+"    "+fq[i].cd+"     "+fq[i].zybz);
				
			}else{
			System.out.println(fq[i].no+"    "+fq[i].qs+"    "+fq[i].cd+"    "+fq[i].zybz);
		}
		}
		System.out.println("--------------------");
		System.out.println("   1:加入工作");
		System.out.println("   2:结束工作");
		System.out.println("--------------------");
		while(true){
			System.out.println("请输入:");
			Scanner scan = new Scanner(System.in);
			int num = scan.nextInt();
			if(num==1){
				System.out.println("请输入你想要加入的工作内存大小:");
				int num1 = scan.nextInt();
				System.out.println("请输入工作名字:");
				scan.nextLine();
				int flag=0;
				int a =10;
				String num2 = scan.nextLine();
				for(int i=0;i<fq.length;i++){
					if(fq[i].cd>=num1){
						a=5;
						flag=5;
					if(fq[i].zybz.equals("0")) {
						fq[i].zybz=num2;
						flag++;
						a--;
						break;
						}	
					}
	
				}
				if(a==10) {
					System.out.println("内存过大");
				}
				
				if(flag==5&&a==5){
					System.out.println("无可分配分区");
				}
				
				for(int i=0;i<fq.length;i++){
					if(fq[i].cd<=10){
						System.out.println(fq[i].no+"    "+fq[i].qs+"    "+fq[i].cd+"     "+fq[i].zybz);
						
					}else{
					System.out.println(fq[i].no+"    "+fq[i].qs+"    "+fq[i].cd+"    "+fq[i].zybz);
				}
				}
				
			}else if(num==2){
				System.out.println("请输入工作名字:");
				scan.nextLine();
				String num2 = scan.nextLine();
				for(int i=0;i<fq.length;i++){
					if(fq[i].zybz.equals(num2)){
						fq[i].zybz="0";
						break;
					}
				}
				for(int i=0;i<fq.length;i++){
					if(fq[i].cd<=10){
						System.out.println(fq[i].no+"    "+fq[i].qs+"    "+fq[i].cd+"     "+fq[i].zybz);
						
					}else{
					System.out.println(fq[i].no+"    "+fq[i].qs+"    "+fq[i].cd+"    "+fq[i].zybz);
				}
				}
				
			}else{
				System.out.println("请输入正确序号!");
			}
		}
		
	}
		

		
}

五、实验结果与讨论

在这里插入图片描述
在这里插入图片描述

  • 3
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您的问题是如何用高级语言编写和调试一个内存连续分配中动态分区分配模拟程序,以加深对进程的概念及进程调度算法的理解。 首先,我们需要了解动态分区分配的基本原理。动态分区分配是指在内存中按需分配一定大小的空间给进程使用。当一个进程需要内存空间时,系统会在空闲内存区域中寻找一块大小足够的空间分配给该进程。当该进程释放内存空间时,系统会将该空间标记为空闲状态,以便后续进程使用。 接下来,我们可以使用高级语言(例如C语言)来实现模拟程序。具体实现步骤如下: 1. 定义内存块结构体(MemoryBlock)来表示内存中的一个连续区域,包括起始地址、结束地址、大小和是否被占用等属性; 2. 定义进程结构体(Process)来表示一个进程,包括进程ID、所需内存大小和已分配内存块等属性; 3. 定义一个动态分区分配函数(allocateMemoryBlock),该函数接受一个进程结构体作为参数,根据进程所需内存大小寻找内存中合适的连续区域,并将该区域分配给该进程; 4. 定义一个内存释放函数(freeMemoryBlock),该函数接受一个进程结构体作为参数,将该进程所占用的内存块标记为空闲状态; 5. 在主函数中模拟多个进程的内存分配和释放过程,输出每个进程的内存分配情况和当前内存状态。 在实现过程中,我们可以使用链表或数组等数据结构来管理内存块和进程,以便更方便地进行内存分配和释放操作。 完成实现后,我们可以通过调试程序来测试其正确性和可靠性,并加深对进程的概念及进程调度算法的理解。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值