大三操作系统要求的课程设计报告,比较完整的主存分配 和回收,采用了要求的三种算法来实现的
2021-07-10 16:14:12 543KB 操作系统 分配与回收
1
这是操作系统两个实验的综合,用java做到,采用图形界面,打包成了jar文件,继而做成了exe安装文件,内置完整的帮助,对于刚学操作系统的新手很有帮助。在xp和jdk1.6下运行通过,我还在继续完善,没有上java源代码(*_*),有意交流者可与我联系:bingo727@qq.com(主要是为了大家一起交流,过段时间我会把源代码一起上传)
2021-07-07 10:59:12 1.8MB 操作系统 图形界面 处理机调度 java
1
主存是中央处理器能够直接存取指令和数据的存储器。能否合理而有效地使用它,在很大程度上将影响整个计算机系统的性能。 提供用户友好的界面设计模拟可变分区管理方式中根据用户的选择使用首次适应算法、最佳适应算法和最差适应算法实现主存的分配与回收。在此过程中,用户可以随时查看当前的内存分配情况,包括每个作业在主存中的位置,所占空间,还有剩余的主存空间。为了更加逼真的模拟主存作业的分配与回收,应该定义该系统所占的内存空间,并且在运行过程中无法回收。此项目帮助理解在不同的存储管理方式下如何实现主存空间的分配和回收
1
独占设备的分配和回收 此实验模拟满足设备独占性的独占设备的分配和回收
1
(1) 可变分区方式是按作业需要的主存空间大小来分割分区的。当要装入一个作业时,根据作业需要的主存容量查看是否有足够的空闲空间,若有,则按需分配,否则,作业无法装入。假定内存大小为128K,空闲区说明表格式为:  起始地址——指出空闲区的起始地址;  长度——一个连续空闲区的长度;  状态——有两种状态,一种是“未分配”状态;另一种是“空表目”状态,表示该表项目前没有使用。 (2) 采用首次适应算法分配回收内存空间。运行时,输入一系列分配请求和回收请求。
2021-05-24 17:17:36 3KB 操作系统 C语言 首次适应算法
1
定义管理空闲分区的相关数据结构:采用空闲分区链表来管理系统中所有的空闲分区,链表中的每个节点表示一个空闲分区,登记有空闲分区的起始地址和长度。 定义一个简单的进程控制块,其中有对应进程分配到的内存的起始地址和长度、以及进程的状态信息。当提交一个作业申请内存的要求时,便为该作业创建一个进程(此时,需要分配给它一个进程控制块以及它需要的内存空间)。简单起见,进程控制块用一个数组来实现,分配给作业n的进程控制块为其中第n个元素;而状态信息中执行和就绪表示为一种状态,忽略阻塞状态。 实现首次适应算法的内存分配函数alloc_mem(int len),其中的参数为所申请的内存空间的长度,函数返回值为所分配到的内存空间的起始地址,分配时优先将空闲区的低端部分分配出去,如果空闲区较大,则留下的高端部分仍为空闲区;实现回收内存的函数free_mem(int base, int len),其中的参数为回收区的起始地址和长度,回收时要求进行空闲分区的合并。 在main()中通过一些具体的分配和回收动作来测试上述内存分配和回收的函数,每完成一个动作,要求将进程的详细信息和所有空闲分区的详细信息显示出来。
2021-05-21 09:00:54 2KB 操作系统 java 数据结构
1
自己做的实验报告,欢迎下载,是你应付操作系统实验报告的不二选择
1
一、实验目的 多道系统中,进程与进程之间存在同步与互斥关系。当就绪进程数大于处理机数时,需按照某种策略决定哪些进程先占用处理机。在可变分区管理方式下,采用首次适应算法实现主存空间的分配和回收。 本实验模拟实现处理机调度及内存分配及回收机制,以对处理机调度的工作原理以及内存管理的工作过程进行更深入的了解。 二、实验内容及要求 1.实验内容 (1)选择一个调度算法,实现处理机调度; (2)结合(1)实现主存储器空间的分配和回收。 2.实验具体要求 (1)设计一个抢占式优先权调度算法实现多处理机调度的程序,并且实现在可变分区管理方式下,采用首次适应算法实现主存空间的分配和回收。 (2)PCB内容包括:进程名/PID;要求运行时间(单位时间);优先权;状态;进程属性:独立进程、同步进程(前趋、后继)。 (3)可以随机输入若干进程,可随时添加进程,并按优先权排序; (4)从就绪队首选进程运行:优先权-1;要求运行时间-1;要求运行时间为0时,撤销该进程;一个时间片结束后重新排序,进行下轮调度; (5)考虑两个处理机,考虑同步进程的处理机分配问题,每次调度后,显示各进程状态,运行进程要显示在哪个处理机上执行。 (6)规定道数,设置后备队列和挂起状态。若内存中进程少于规定道数,可自动从后备队列调度一作业进入。被挂起进程入挂起队列,设置解挂功能用于将制定挂起进程解挂入就绪队列。 (7)结合实验一pcb增加所需主存大小,主存起始位置;采用首次适应算法分配主存空间。 (8)自行假设主存空间大小,预设操作系统所占大小并构造未分分区表。表目内容:起址、长度、状态(未分/空表目)。 (9)进程完成后,回收主存,并与相邻空闲分区合并。 (10)最好采用图形界面;
1
连续的磁盘存储空间的分配和回收 模拟UNIX系统的空闲块成组链接法,实现磁盘存储空间的管理。 用位示图管理磁盘存储空间
2021-05-19 10:51:50 150KB 磁盘存储空间
1
在可变分区管理方式下,采用首次适应算法(最先适应算法)实现主存空间的分配和回收。操作系统课程设计,用C语言实现。在VC6.0上调试通过。
1