操作系统动态内存分配

操作系统动态内存分配

ID:6699593

大小:30.00 KB

页数:7页

时间:2018-01-22

操作系统动态内存分配_第1页
操作系统动态内存分配_第2页
操作系统动态内存分配_第3页
操作系统动态内存分配_第4页
操作系统动态内存分配_第5页
资源描述:

《操作系统动态内存分配》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、packagecom.gaojingdian.arithmetic;importjava.io.IOException;importjava.util.ArrayList;importjava.util.LinkedList;importjava.util.List;importcom.gaojingdian.DataFrame.PCB;importcom.gaojingdian.DataFrame.Subarea;importcom.gaojingdian.MainMemorySubarea.MainMemorySubarea;import

2、com.gaojingdian.MainMemorySubarea.RevokeMemory;/***最佳适应算法**/publicclassBestFitextendsFCFS{privateListreadyList=newArrayList();//就绪队列privateListallocationList=newLinkedList();//已分分配分区队列privatestaticMainMemorySubareamms=null;privatePCBlastPCB=null;

3、privateSubarearevokeSubarea=null;//当前要释放的分区privateListemptySubarea=null;//空闲队列privateListlist=null;//中间容器static{mms=newMainMemorySubarea();}//用FCFS调度算法从后备队列中往内存中调入满足条件的作业,并用最佳适应算法为作业分配内存空间privatevoidenterReadyList()throwsIOException{mms.initFreeList();if(empty

4、Subarea==null)emptySubarea=mms.getSubareaList();for(inti=0;i

5、(emptySubarea.get(j).getSize());rsb.setBeginAddress(emptySubarea.get(j).getBeginAddress());rsb.setPcbId(list.get(i).getId());allocationList.add(rsb);emptySubarea.remove(emptySubarea.get(j));}else{Subareasa=emptySubarea.get(j);Subarearsb=newSubarea();rsb.setSize(list.get(i).

6、getProcessSize());rsb.setBeginAddress(sa.getBeginAddress());rsb.setPcbId(list.get(i).getId());allocationList.add(rsb);sa.setBeginAddress(sa.getBeginAddress()+list.get(i).getProcessSize());sa.setSize(sa.getSize()-list.get(i).getProcessSize());}list.get(i).setLogo2(1);break;}

7、if(j==-1)list.get(i).setLogo1(1);}}//执行进程,并回收内存空间publicvoidbestFit()throwsIOException{PCBpcb=null;inttemp=10000;intindex=0;while(true){list=super.selectProcess(readyList,lastPCB);this.enterReadyList();temp=10000;if(readyList.size()!=0){if(this.getCount()!=readyList.size()){

8、for(inti=0;i

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。