"动态分区分配算法模拟及实现任务计划书"

0 下载量 182 浏览量 更新于2024-01-16 收藏 258KB DOC 举报
本次计算机科学操作系统专业课程设计任务是动态分区分配方法模拟,要求用C语言实现采取首次适应算法的动态分区分配过程alloc()和回收过程free()。在系统初始状态下,可用内存空间为640KB,并有一系列作业的申请和释放请求序列,需要根据首次适应算法进行内存块的分配和回收,并显示分配和回收后的空闲内存分区链情况。 本次任务的主要内容包括以下几点: 1. 使用C语言实现动态分区分配过程alloc()和回收过程free()的功能。在内存分配时,系统优先使用低端空间的空闲区作为分配对象。使用合适的数据结构和算法来管理空闲分区链表。 2. 了解动态分区分配中使用的数据结构和分配算法。深入理解动态分区存储管理方法及其实现过程。可以参考《操作系统原理实用教程》和《计算机操作系统》等相关教材来扩充知识。 任务要求对动态分区分配方法有深入了解,并能够实现首次适应算法来进行内存块分配和回收。此外,还需要能够显示分配和回收后的空闲内存分区链情况。 对于本次任务,可以采取如下步骤进行实现: 1. 首先,需要定义一个结构体来表示内存分区的信息,包括起始地址、分区大小以及分配状态等。 2. 接着,可以定义一个链表结构来管理空闲分区,每个节点表示一个空闲分区,包括指向下一个节点的指针和分区的信息。 3. 在分配过程alloc()中,首先遍历空闲分区链表,找到第一个满足大小需求的空闲分区,将其分配给作业,并更新空闲分区链表。 4. 在回收过程free()中,首先找到作业对应的分区,将其释放,然后根据释放的分区信息更新空闲分区链表。 5. 在每次分配和回收后,都需要显示空闲内存分区链的情况,可以打印出每个空闲分区的起始地址和大小。 通过以上步骤,就能够完成动态分区分配方法的模拟,实现首次适应算法对内存块的分配和回收,并且能够显示分配和回收后的空闲内存分区链情况。 总之,本次任务要求通过C语言实现首次适应算法的动态分区分配过程alloc()和回收过程free(),并展示分配和回收后的空闲内存分区链情况。需要深入了解动态分区存放管理方法及其实现过程,并使用适合的数据结构和算法来管理空闲分区链表。可以参考相关教材来加深对动态分区分配的理解。
2023-05-25 上传
计算机操作系统课程设计 班级:计091-1 姓名: 学号: 使用语言:C++ 指导老师: 学院: 系统要求 1、实验目的 通过一个简单多用户文件系统的设计,加深理解文件系统的内部功能及内部实现。 2、实验内容 为linux系统设计一个简单的二级文件系统。要求做到以下几点: (1)可以实现下列几条命令(至少4条); login 用户登陆 dir 列文件目录 create 创建文件 delete 删除文件 open 打开文件 close 关闭文件 read 读文件 write 写文件 (2)列目录时要列出文件名、物理地址、保护码和文件长度; (3)源文件可以进行读写保护。 二、系统分析 1、设计思想 本文件为二级文件系统,即要实现对文件的增删改查,同时又具备登陆系统、注册用 户的功能,各个用户之间的文件系统互不干扰。 本文件系统采用两级目录,其中第一级对应于用户账号,第二级对应于用户帐号下的 文件。另外,为了简便文件系统未考虑文件共享,文件系统安全以及管道文件与设备文 件等特殊内容。 系统采用结构体来存储用户、文件目录、文件数据内容: 0 48*5 48*5+44*50 48*5+44*50+264*200 每个分区都是由结构体组成,每个个去的结构体的个数由格式化系统是决定。 整个系统的编码构成主要分为: Allstruct.h 定义了每个分区的结构体; Mysys.h 声明了对系统操作的各种方法; Myuserfile.h 声明了对文件操作的各种方法; Mymain.cpp 整个系统的主函数,操作入口; Mysys.cpp 包含了mysys.h,实现了操作系统的各种方法; Myuserfile.cpp 包含了myuserfile.h,实现了操作文件的各种方法; 2、主要数据结构 Allstruct.h文件的内容: struct s_user //用户区结构体 { long isuse; //是否使用 char name[20]; //用户名 char psd[20]; //密码 long address; //目录地址 }; struct s_list //目录结构体 { long isuse; //是否使用 char name[20]; //文件名字 long myaddress; //本条目录地址 long pointaddress; //指向的文件的地址 long isfile; //是否锁定 long pointsize; //目标文件的大小 long nextaddress; //下条目录的地址 }; struct s_file //文件结构体 { long isuse; //是否使用 char content[256]; //文件内容 long next; //下个文件块地址 }; 系统执行 1. 如果首次进入系统,还没有文件系统,则会提示格式化文件系统,创建分区,并初始化 分区: 2、刚初始化后,没有用户,提示创建用户: 3、用户创建成功后出现对系统操作的菜单 4、注册用户功能: 5、用户登录,登录成功后显示当前用户下的所有文件及其详细信息,同时显示对文件操 作的菜单: 6、新注册的用户默认为没有文件,选择创建文件,并且每次对文件操作后显示当前用户 的所有文件和操作菜单: 7、此次新建的文件为锁定状态,不能被删除: 8、对文件查看,默认创建的时候用0填充文件内容: 9、修改文件内容: 10、对文件的锁定进行装换: 11、删除文件: 12、注销登录退出系统: 功能实现 Mysys.h #include <stdio.h> #include "myuserfile.h" class MSysterm { //封装了管理系统的方法 //成员变量 private: FILE *myfile; MUser myuser; //成员函数 public: MSysterm(){} void outName(); //打印登陆后的用户名 int cheack(); //检查虚拟文件系统跟是否存在 int myformat(); //初始化虚拟磁盘 int createuser(); //创建用户 int login(); //用户登录 void mymain(); //主控制程序 int logout(); //用户注销 }; Myuserfile.h #include <stdio.h> class MUser //封装了管理文件的方法 { //成员变量 public: FILE *myfile; char name[20]; //用户名 char psd[20]; //密码 long listaddress; //目录地址 long myaddress; //此用户的地址 private: long lastaddress;