页面fifo.docVIP

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
页面fifo

#includeiostream #includetime.h using namespace std; int inputSize; int memorySize; int *in; //请求序列 int *memory; //模拟内存 void FIFO(); struct page { int pageNum; int memoryNum; int isInmemory; }; page pageTable[10]; //假设虚拟页面数10个,页表长度10 int main() { for(int i=0;i10;i++) //初始化页表 { pageTable[i].pageNum=i; pageTable[i].memoryNum=-1; pageTable[i].isInmemory =0; } cout输入待调入页面数endl; cininputSize; cout输入可使用的物理块数endl; cinmemorySize; in= new int[inputSize]; memory=new int[memorySize]; int temp; int select; srand( (unsigned)time( NULL ) ); cout随机生成请求序列?(1是)endl; cinselect; if(select==1) { cout随机生成页面请求序列(0-9)endl; for( i=0;iinputSize;i++) { temp=rand()%10; couttemp ; in[i]=temp; } } else { cout输入inputSize个页面号(0-9)endl; for( i=0;iinputSize;i++) { cintemp; in[i]=temp; } } coutendl; FIFO(); delete [] in; delete [] memory; return 0; } void FIFO() //FIFO替换算法实现函数 { coutFIFO替换算法:endl; for(int i=0;imemorySize;i++) { memory[i]=-1; } int lackTime=0; //记录缺页次数 int firstIn=0; //记录最先被占用的物理块号,装有最先进入内存的页面号 int isFull=0; //记录物理块是否已被占满,当isFull=3时表示已经装满,如果再缺页则发生替换 int page=0; //记录将要访问的页面号 do //物理块未被占满时 { if(pageTable[in[page]].isInmemory ==1) // in[i]在memory中 { coutin[page] is in memoryendl; page++; if(page==inputSize)break; else continue; } else { lackTime++; coutin[page] not in memory!endl; // 装入内存 memory[isFull]=in[page]; for(int j=0;j10;j++) { if( pageTable[j].memoryNum== isFull) { pageTable[j].memoryNum=-1; pageTable[j].isInmemory=0; break; } } pageTable[in[page]].isInmemory=1; pageTable[in[page]].memoryNum=isFull; isFull++; page++; if(page==inputSize)break; } }while(isFull!=memorySize); //物理块被占满时退出循环 for( i=

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档