南通大学计算机科学与技术学院操作系统课程设计报告专业:学生姓名:学号:时间:操作系统模拟算法课程设计报告设计要求将本学期三次的实验集成实现:A.处理机管理;B.存储器管理;C.虚拟存储器的缺页调度。
设计流程图主流程图A.处理机调度1)先来先服务FCFS先来先服务算法流程2)时间片轮转法时间片轮转算法流程图B.存储器管理(可变式分区管理)1)首次适应法分配流程图首次适应算法回收流程图2)最佳适应法回收内存流程C.虚拟存储器的缺页调度1)先进先出FIFO2)LRU实现原理主界面设计一个框架分别去链接处理机管理、存储器管理和缺页调度相关的程序。
A.处理机调度1)先来先服务FCFS(一)任务先来先服务的调度算法实现处理机调度。
(二)要求1.实现对FCFS算法的模拟实现2.计算出该算法的平均作业周转时间、平均带权作业周转时间。
(三)原理按作业到达CPU时间先后顺序进行非剥夺式调度,先到达CPU的作业先被执行。
(四)数据结构struct task_struct{char name; /*进程名称*/int number; /*进程编号*/float come_time; /*到达时间*/float run_begin_time; /*开始运行时间*/float run_time; /*运行时间*/float run_end_time; /*运行结束时间*/int priority; /*优先级*/int order; /*运行次序*/int run_flag; /*调度标志*/}tasks[MAX];*/进程名链接指针到达时间估计运行时间进程状态(五)实现方法建立一个链表按照到达CPU的时间从小到大排列,只需从第一个作业(头结点)依次调度到最后一个作业(尾结点)。
(六)运行界面作业名到达时间运行时间A 0 28B 0 9C 0 32)时间片轮转法(一)任务只对进程的运行模拟,将其运行时间加一,判断要求运行时间与已运行时间是否相等,若相等则表示进程结束,进程退出调度,释放资源。
(二)要求1.实现对RR算法的模拟实现2.显示执行完一个时间片的结果。
(三)原理时间片轮转算法中,系统将所有的就程序按先来先服务的原则排成一个队列,每次调度时,把CPU分配给队首进程,并令其执行一个时间片。
当执行的时间片用完时,调度程序停止该进程的执行,并将它送往就绪队列的末尾;然后,再把处理机分配给就绪队列中新的队首进程,同时也让它执行一个时间片。
(四)数据结构temp->state='R'; //初始状态每个进程均为运行态temp->allocation=0; //初始时进程均不占用cpunum+=temp->need_time; //用num来限制循环的次数(五)实现方法处理器调度总是选择标志单元指示的进程运行。
执行:已运行时间+1来模拟进程的一次运行,表示进程已经运行过一个单位的时间。
当一个进程被选中运行时,必须设置该进程可以运行的时间片值,以及恢复进程的现场,让它占有处理器运行,直到出现等待事件或运行满一个时间片进程运行一次后,应把该进程的进程控制块中的指针值送到标志单元,以指示下一个轮到运行的进程。
同时,应判断该进程的要求运行时间与已运行时间,若该进程的要求运行时间 已运行时间,则表示它尚未执行结束,应待到下一轮时再运行。
若该进程的要求运行时间=已运行时间,则表示它已经执行结束,应指导它的状态修改成“结束”且退出队列。
此时,应把该进程的进程控制块中的进程名链接指针到达时间估计运行时间进程状态(六)运行界面作业号执行时间/sA 1B 2C 1B.存储器管理(可变式分区管理)1)首次适应法(一)任务通过采用首次适应算法实现内存的分配与回收,并可以查看和显示当前内存现状。
(二)要求1.实现对FF算法的模拟实现2.输入要进行分配内存的进程ID和相应所需内存大小,回收内存时输入已运行的进程ID。
(三)原理FF算法要求空闲链已地址递增的次序连接。
分配内存时,从链首开始顺序查找,直到找到第一个满足要求的空间并分配给进程,把分配后余下的空间仍然留在链表中。
若从链首至链尾都不满足要求,则分配失败。
该算法倾向于优先使用低地址的空间。
(四)数据结构int const MEMO=256;//初始化常类型MEMO,用MEMO表示内存大小(常类型的变量或对象的值是不能被更新的)struct FreeMemory{int ID;int StartAdd;int Size;bool State;//定义state 为布尔型变量,其值只有真(TRUE) 和假(FALSE) FreeMemory* Next;};FreeMemory* AllocTable=new FreeMemory;//建立全局管理表用于内与回收FreeMemory* PtrforCycleFit=AllocTable;//为循环首次适应定义的指针,此指针用于指向当前查找的起始地址;//初始化内存函数void MemoryInit(FreeMemory* &tempAdd){tempAdd->ID=0;//初始化当前进程为空tempAdd->Size=MEMO;//初始化可分配空间为内存大小tempAdd->StartAdd=0;//初始化起始地址为0tempAdd->State=false;// 初始化状态为未分配tempAdd->Next=NULL;//初始化下一个进程也为空}//反馈内存现态void DispMemory(){FreeMemory* temp=AllocTable;//全局管理表反映内存状态cout<<"系统总内存: "<<MEMO<<endl;for(;temp;temp=temp->Next)cout<<"进程ID:"<<temp->ID<<" "<<"大小:"<<temp->Size<<" "<<"起始地址:"<<temp->StartAdd<<" "<<"是否已分配:"<<temp->State<<endl;}// 输出内存的各个变量(五)实现方法可变式分区管理是指在处理作业过程中建立分区,使分区大小正好适合作业的需要,并且分区的个数是可以调整的。
当需要装入一个作业时,根据作业需要的贮存量,查看是否有足够的空闲空间,若有,则按需求量分割一部分给作业;若无,则作业等待。
随着作业的装入、完成,主存空间被分割成许多大大小小的分区。
有的分区被分配作业占用,有的分区空闲。
在空闲区表中,按空闲区首地址从低到高进行登记。
当一个作业执行完成时,作业所占用的分区应归还给系统。
在归还时,要考虑相邻空间区合并问题。
作业的释放区与空闲区的邻接分以下4种情况考虑:A、释放区下邻空闲区;B、释放区上邻空闲区;C、释放区上下都与空闲区邻接;D、释放区上邻空闲区不邻接。
(六)运行界面系统总内存为256时,分别为进程1、2、3分配大小为64、128、64的内存。
执行首次适应算法分配内存如下:若回收进程2的内存,执行结果如下:2)最佳适应法(一)任务通过采用最佳适应算法实现内存的分配与回收,并可以查看和显示当前内存现状。
(二)要求1.实现对BF算法的模拟实现2.输入要进行分配内存的进程ID和相应所需内存大小,回收内存时输入需要回收的内存块。
(三)原理最佳适应算法扫描整个未分配表或链表,从空闲区中挑选一个能满足用户进程要求的最小分区进行分配。
此算法保证不会分割一个更大的区域,使得装入大作业的要求容易得到满足,同时,通常把空闲区按长度递增顺序排列,查找时总是从最小的一个空闲区开始,直至找到满足要求的分区为止,这时,最佳适应分配算法等同于首次适应算法。
此算法的主存利用率好,所找出的分区如果最好满足要求则是最合适的。
(四)数据结构int const MEMO=256;//初始化常类型MEMO,用MEMO表示内存大小(常类型的变量或对象的值是不能被更新的)struct FreeMemory{int ID;int StartAdd;int Size;bool State;//定义state 为布尔型变量,其值只有真(TRUE) 和假(FALSE) FreeMemory* Next;};bool Alloc_BestFit(int id,int TrySize){//查找满足此条件的x1<=TrySize<=x2 的分区,然后将其放置在x2中,并将x2拆分成两个分区SortPartition(true);//使用快速排序算法,升序排序for(;temp;temp=temp->Next){/*回收操作,回收过程中,要用到三个指针,上一个Last,当前temp,下一个temp->next当temp指向表头或表尾时需要特殊考虑*///当要退出工作时,就要回收//此退出的工作由执行函数调用void EndJob(int id){Free_Memory(id);}(五)实现方法(六)运行界面测试数据如下:所需内存25 34 45 12 13 10若回收进程4,执行结果如下:C.虚拟存储器的缺页调度1)先进先出FIFO(一)任务采用先进先出FIFO算法实现分页管理的缺页调度,并输出每次调入调出的页号和运行结果。
(二)要求1.实现对FIFO算法的模拟实现2.输出每次执行的结果。
(三)原理基于程序总是按线性顺序来访问物理空间这一假设,总是淘汰最先调入主存的页面,即淘汰在主存中驻留时间最长的页面,认为驻留时间最长的页不再使用的可能性较大。
(四)数据结构void FIFO(){int length;int fifo[100]={0};int pageLength;int fifoPage[100]={0};int i,j;cout<<" ***********************先进先出算法**************************"<<endl;pageLength=3;length=9;for(i=1;i<=length;i++){int flag=0;for(j=1;j<=pageLength;j++){if(fifo[i]==fifoPage[j]){flag=1;j=pageLength+1;}else if(fifoPage[j]==0){fifoPage[j]=fifo[i];j=pageLength+1;flag=1;}}if(flag==1){}else{cout<<" →淘汰"<<fifoPage[1]<<endl;for(j=1;j<=pageLength;j++){fifoPage[j]=fifoPage[j+1];}fifoPage[pageLength]=fifo[i];}(五)实现方法当采用先进先出算法时,用一个数组构成先进先出队列,数组中各个元素为进程已在主存的页号,其队列头指针初始化为0.假设分配给每个进程的内存块数固定。