下载后可任意编辑操作系统实验报告院别:XXXXXX班级:XXXXXX学号:XXXXXX姓名:稻草人下载后可任意编辑实验题目:内存管理实验一、 实验目的1、通过本次试验体会操作系统中内存的分配模式;2、掌握内存分配的方法(FF,BF,WF);3、学会进程的建立,当一个进程被终止时内存是如何处理被释放块,并当内存不满足进程申请时是如何使用内存紧凑;4、掌握内存回收过程及实现方法;5、学会进行内存的申请释放和管理;二、 实验内容 附源代码: /*宏定义*/#include#include#include#define PROCESS_NAME_LEN 32 /*进程名称的最大长度*/#define MIN_SLICE 10 /*最小碎片的大小*/#define DEFAULT_MEM_SIZE 1024 /*默认内存的大小*/#define DEFAULT_MEM_START 0 /*默认内存的起始位置*//* 内存分配算法 */#define MA_FF 1#define MA_BF 2#define MA_WF 3int mem_size=DEFAULT_MEM_SIZE; /*内存大小*/int ma_algorithm = MA_FF; /*当前分配算法*/int flag = 0; /*设置内存大小标志*/static int pid = 0; /*初始pid*/int algorithm;/*描述每一个空闲块的数据结构*/struct free_block_type{ int size; int start_addr; struct free_block_type *next;}; 下载后可任意编辑/*指向内存中空闲块链表的首指针*/struct free_block_type *free_block;/*每个进程分配到的内存块的描述*/struct allocated_block{ int pid; int size; int start_addr; char process_name[PROCESS_NAME_LEN]; struct allocated_block *next; };/*进程分配内存块链表的首指针*/struct allocated_block *allocated_block_head = NULL; struct allocated_block *find_process(int id){ struct allocated_block *p;p=allocated_block_head;while(p!=NULL){ if (p->pid==id) return p;}return NULL;}void swap(int *p,int *q){ int temp; temp = *p; *p = *q; *q = temp; return;}void do_exit(){ exit(0);}/*初始化空闲块,默认为一块,可以指定大小及起始地址*/struct free_block_type* init_free_block(int mem_size){下载后可任意编辑 struct free_block_type *fb; fb=(struct free_block_type *)malloc(sizeof(struct free_block_type)); if(fb==NULL){ printf("No mem\n"); return NULL; } fb->size = mem_size; fb->start_addr =...