欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言實(shí)現(xiàn)頁(yè)面置換 先進(jìn)先出算法(FIFO)

 更新時(shí)間:2020年12月29日 11:28:16   作者:little pepper  
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)頁(yè)面置換,先進(jìn)先出算法(FIFO),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)頁(yè)面置換算法的具體代碼,供大家參考,具體內(nèi)容如下

一、設(shè)計(jì)目的   

加深對(duì)請(qǐng)求頁(yè)式存儲(chǔ)管理實(shí)現(xiàn)原理的理解,掌握頁(yè)面置換算法中的先進(jìn)先出算法。

二、設(shè)計(jì)內(nèi)容

設(shè)計(jì)一個(gè)程序,有一個(gè)虛擬存儲(chǔ)區(qū)和內(nèi)存工作區(qū),實(shí)現(xiàn)下述三種算法中的任意兩種,計(jì)算訪問(wèn)命中率(命中率=1-頁(yè)面失效次數(shù)/頁(yè)地址流長(zhǎng)度)。附加要求:能夠顯示頁(yè)面置換過(guò)程。

該系統(tǒng)頁(yè)地址流長(zhǎng)度為320,頁(yè)面失效次數(shù)為每次訪問(wèn)相應(yīng)指令時(shí),該指令對(duì)應(yīng)的頁(yè)不在內(nèi)存的次數(shù)。   
程序首先用srand()和rand()函數(shù)分別進(jìn)行初始化、隨機(jī)數(shù)定義和產(chǎn)生指令序列,然后將指令序列變換成相應(yīng)的頁(yè)地址流,并針對(duì)不同的算法計(jì)算出相應(yīng)的命中率。

通過(guò)隨機(jī)數(shù)產(chǎn)生一個(gè)指令序列。共320條指令,指令的地址按下述原則生成:

(1)50%的指令是順序執(zhí)行的。
(2)25%的指令是均勻分布在前地址部分。
(3)25%的指令是均勻分布在后地址部分。

具體的實(shí)施方法如下:

在【0,319】的指令地址之間隨機(jī)選取一起點(diǎn)m。
順序執(zhí)行一條指令,即執(zhí)行地址為m+1的指令。
在前地址【0,m+1】中隨機(jī)選取一條指令并執(zhí)行,該指令的地址為m'。
順序執(zhí)行一條指令,其地址為m'+1。
在后地址【m'+2,319】中隨機(jī)選取一條指令并執(zhí)行。
重復(fù)步驟(1)-(5),直到320次指令。
將指令序列變換為頁(yè)地址流。

設(shè):

頁(yè)面大小為1KB。
用戶內(nèi)存容量4頁(yè)到32頁(yè)。
用戶虛存容量為32KB。
在用戶虛存中,按每K存放10條指令虛存地址,即320條指令在虛存中的存放方式為:
第0條~9條指令為第0頁(yè)(對(duì)應(yīng)虛存地址為【0,9】)。
第10條~19條指令為第1頁(yè)(對(duì)應(yīng)虛存地址為【10,19】)。
……
第310條~319條指令為第31頁(yè)(對(duì)應(yīng)虛擬地址為【310,319】)。
按以上方式,用戶指令可組成32頁(yè)。
計(jì)算每種算法在不同內(nèi)存容量下的命中率。

三、程序結(jié)構(gòu)

首先,用srand()和rand()函數(shù)分別進(jìn)行初始化、隨機(jī)數(shù)定義和產(chǎn)生指令序列;
接著,將指令序列變換成相應(yīng)的頁(yè)地址流;
然后,并針先進(jìn)先出算法計(jì)算出相應(yīng)的命中率和輸出頁(yè)面置換過(guò)程。

源程序:

#include<stdio.h>
#include<stdlib.h>
#define N 320
int num[N]; //存放隨機(jī)數(shù) 
int page[N]; //存放頁(yè)地址流 
int mc[33]; //memory capacity內(nèi)存容量 ,并初始化為0 
 
void randomnumber()//random number隨機(jī)數(shù) 程序第一步,產(chǎn)生320個(gè)指令序列 
{ 
 int pc;
 int flag=0; 
 scanf("%d",&pc); 
 printf("\n在0-319之間產(chǎn)生的320個(gè)隨機(jī)數(shù)如下:\n"); 
 for(int i=0;i<320;i++) 
 { 
 num[i]=pc; 
 if(flag%2==0) pc=++pc%320; //flag=0||2 50%的指令是順序執(zhí)行的 
 if(flag==1) pc=rand()% (pc-1); //flag=1 25%的指令是均勻分布在前地址部分 
 if(flag==3) pc=pc+1+(rand()%(320-(pc+1))); //flag=3 25%的指令是均勻分布在后地址部分 
 flag=++flag%4; 
 printf("%3d ",num[i]); 
 if((i+1)%10==0) printf("\n"); //每行輸出10個(gè)數(shù) 
 } 
} 
 
void pageaddress() //pageaddress頁(yè)地址 程序第二步,將指令序列變換為頁(yè)地址流 
{ 
 for(int i=0;i<320;i++) 
 { 
 printf("%3d ",page[i]=num[i]/10); 
 if((i+1)%10==0) printf("\n"); //每行輸出10個(gè)數(shù) 
 } 
}
 
int FIFO(int capacity)
{
 int j,x,y,m;
 int sum=0; //mc中分配的個(gè)數(shù) 
 int exist=0; //命中次數(shù) 
 int flag; //標(biāo)志是否命中 flag=0沒(méi)命中 flag=1命中 
 int ep=1; //elimination position淘汰位置 
 mc[1]=page[0];
 printf(" %2d加入 \t",page[0]);
 for(m=1;m<=capacity;m++) //輸出當(dāng)前內(nèi)存塊的存儲(chǔ)情況 
 printf("%2d ",mc[m]);
 printf("\n");
 sum+=1; 
 for(j=1;j<320;j++)
 { 
 flag=0; 
 for(y=1;y<=sum;y++) //判斷這個(gè)頁(yè)地址流是否命中 
 if(mc[y]==page[j]) {
 exist++;
 flag=1;
 printf(" %2d命中 \t",page[j]);
 for(m=1;m<=capacity;m++) //輸出當(dāng)前內(nèi)存塊的存儲(chǔ)情況 
 printf("%2d ",mc[m]);
 printf("\n");
 break;} 
 //沒(méi)命中 
 if(flag==0) 
 {
 if(sum<capacity) //還有空塊 
 {for(x=1;x<=capacity;x++) //查找內(nèi)存塊中第一個(gè)空塊 
 if(mc[x]==-1) {
 mc[x]=page[j];
 sum++;
 printf(" %2d加入 \t",page[j]);
 for(m=1;m<=capacity;m++) //輸出當(dāng)前內(nèi)存塊的存儲(chǔ)情況 
 printf("%2d ",mc[m]);
 printf("\n");
 break;}
 }
 else if(sum>=capacity)
 {
 int t=mc[ep];
 mc[ep]=page[j];
 printf(" %2d置換%2d\t",page[j],t);
 for(m=1;m<=capacity;m++) //輸出當(dāng)前內(nèi)存塊的存儲(chǔ)情況 
 printf("%2d ",mc[m]);
 printf("\n");
 ep+=1;
 if(ep==capacity+1) ep=1; 
 } 
 }
 } 
 printf("\nexist=%d\n命中率=%lf",exist,exist/320.0);
} 
int main()
{
 int capacity; //內(nèi)存塊數(shù) 
 printf("請(qǐng)輸入第一條指令號(hào)(0~319):");
 randomnumber();
 printf("\n指令序列對(duì)應(yīng)的頁(yè)地址流:\n"); 
 pageaddress(); 
 printf("\n\n\n\t\t先進(jìn)先出算法(FIFO):\n\n");
 printf("請(qǐng)輸入內(nèi)存塊數(shù)(4-32):");
 scanf("%d",&capacity);
 for(int i=1;i<=32;i++) //給數(shù)組賦初值 
 mc[i]=-1;
 FIFO(capacity); 
 return 0;
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用C語(yǔ)言訪問(wèn)51單片機(jī)中存儲(chǔ)器的核心代碼

    使用C語(yǔ)言訪問(wèn)51單片機(jī)中存儲(chǔ)器的核心代碼

    這篇文章主要介紹了使用C語(yǔ)言訪問(wèn)51單片機(jī)中存儲(chǔ)器的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-01-01
  • C語(yǔ)言詳解strcmp函數(shù)的分析及實(shí)現(xiàn)

    C語(yǔ)言詳解strcmp函數(shù)的分析及實(shí)現(xiàn)

    strcmp函數(shù)語(yǔ)法為“int strcmp(char *str1,char *str2)”,其作用是比較字符串str1和str2是否相同,如果相同則返回0,如果不同,前者大于后者則返回1,否則返回-1
    2022-05-05
  • C語(yǔ)言數(shù)組詳細(xì)介紹

    C語(yǔ)言數(shù)組詳細(xì)介紹

    大家好,本篇文章主要講的是C語(yǔ)言數(shù)組詳細(xì)介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • 基于MFC實(shí)現(xiàn)貪吃蛇小游戲

    基于MFC實(shí)現(xiàn)貪吃蛇小游戲

    這篇文章主要為大家詳細(xì)介紹了基于MFC實(shí)現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C++實(shí)現(xiàn)從輸入中讀取字符串

    C++實(shí)現(xiàn)從輸入中讀取字符串

    這篇文章主要介紹了C++實(shí)現(xiàn)從輸入中讀取字符串的實(shí)現(xiàn)思路和具體代碼,非常的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下
    2016-05-05
  • 解決 VSCode 編寫 C++11 代碼報(bào)紅問(wèn)題分析

    解決 VSCode 編寫 C++11 代碼報(bào)紅問(wèn)題分析

    今天在寫 C++ 代碼的時(shí)候用上 C++11 的特性,然后發(fā)現(xiàn) VSCode 雖然可以編譯通過(guò),但是會(huì)在相應(yīng)位置報(bào)紅,這是怎么回事呢?下面小編給大家?guī)?lái)了解決方法,一起看看吧
    2021-09-09
  • CLion開發(fā)stm32?使用DSP庫(kù)的操作方法

    CLion開發(fā)stm32?使用DSP庫(kù)的操作方法

    這篇文章主要介紹了CLion開發(fā)stm32?使用DSP庫(kù)的方法,首先需要添加DSP庫(kù)文件到工程目錄,修改CMakeLists,添加STM32HAL庫(kù),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • C++實(shí)現(xiàn)屏幕截圖

    C++實(shí)現(xiàn)屏幕截圖

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)屏幕截圖功能,截圖自動(dòng)保存為png格式文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • C++全面細(xì)致講解復(fù)數(shù)類

    C++全面細(xì)致講解復(fù)數(shù)類

    本文章向大家介紹C++ 標(biāo)準(zhǔn)庫(kù)中的復(fù)數(shù)類,主要包括C++ 標(biāo)準(zhǔn)庫(kù)中的復(fù)數(shù)類使用實(shí)例、應(yīng)用技巧、基本知識(shí)點(diǎn)總結(jié)和需要注意事項(xiàng),具有一定的參考價(jià)值,需要的朋友可以參考一下
    2022-06-06
  • 新手向超詳細(xì)的C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)順序表

    新手向超詳細(xì)的C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)順序表

    本文主要介紹了C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)順序表,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評(píng)論