本项目旨在研究和实现操作系统中基于分页的存储管理和多进程环境下的内存动态分配机制,通过模拟实验深入理解其工作原理及优化方法。
在模拟操作系统中的内存分配(分页存储管理)过程中,连续的分配方式会产生大量碎片,尽管可以通过紧凑的方法将这些碎片拼接成可用的大块空间来解决这一问题,但这需要付出较大的开销。如果允许进程直接分散地装入到许多不相邻的分区中,则可以避免这种麻烦而不必进行内存整理。基于这样的想法产生了离散分配的方式,当这种方式是页时则被称为分页存储管理方式。
1. **目的**: 内存管理是操作系统的重要组成部分。本设计要求用高级语言编写一个模拟简单的内存管理系统程序。通过这个实验能够更好地理解常见操作系统的内存管理模块的实现方法。
2. **具体要求**
- 设计用户程序数组、进程控制块(PCB)、页表和内存分配表等数据结构;
- 编写代码以模拟操作系统进行动态内存管理和回收的过程。
(1) 初始条件: 用文本段落件存储以下信息:
内存总大小以及各个进程的数据,包括到达时间、结束时间和所需内存的大小。
(2) 运行过程: 程序首先读取初始文档中的数据;然后根据这些数据来模拟操作系统进行内存分配与回收的过程。要求程序能够输出中间状态和最终结果(最好能将信息写入文件),例如某时刻进程的页表、整个系统的内存使用情况等,以及尽可能地动态展示此过程。