实验三、页式地址重定位模拟

实验三、页式地址重定位模拟

一、实验目的:

1、  用高级语言编写和调试模拟实现页式地址重定位。

2、  加深理解页式地址重定位技术在多道程序设计中的作用和意义。

二、实验原理:

当进程在CPU上运行时,如指令中涉及逻辑地址时,操作系统自动根据页长得到页号和页内偏移,把页内偏移拷贝到物理地址寄存器,再根据页号,查页表,得到该页在内存中的块号,把块号左移页长的位数,写到物理地址寄存器。

三、实验内容:

1、  设计页表结构

2、  设计地址重定位算法

3、  有良好的人机对话界面

三、程序调试:

调试数据一:

系统页号对应块号情况(页号——>块号):

 0--> 0   1-->42   2-->29   3-->15   4-->45   5-->31   6-->44   7-->43

 8-->41   9-->28  10--> 1  11-->30  12-->12  13-->24  14--> 6  15-->32

16-->14  17-->27  18-->13  19-->46  20--> 7  21-->33  22-->10  23-->22

24-->40  25--> 2  26-->51  27-->11  28-->39  29-->23  30-->49  31-->50

32-->26  33-->16  34-->25  35--> 4  36-->47  37-->17  38--> 3  39-->48

40-->52  41-->36  42-->58  43-->35  44-->57  45-->34  46-->21  47-->63

48--> 5  49-->37  50-->18  51--> 8  52-->62  53-->56  54-->20  55-->54

56-->60  57-->19  58-->38  59--> 9  60-->61  61-->55  62-->59  63-->53

请输入逻辑地址(十进制):

2500

对应的物理地址为(十进制):

30148

Press any key to continue

调试数据二:

系统页号对应块号情况(页号——>块号):

 0--> 0   1-->42   2-->29   3-->15   4-->45   5-->31   6-->44   7-->43

 8-->41   9-->28  10--> 1  11-->30  12-->12  13-->24  14--> 6  15-->32

16-->14  17-->27  18-->13  19-->46  20--> 7  21-->33  22-->10  23-->22

24-->40  25--> 2  26-->51  27-->11  28-->39  29-->23  30-->49  31-->50

32-->26  33-->16  34-->25  35--> 4  36-->47  37-->17  38--> 3  39-->48

40-->52  41-->36  42-->58  43-->35  44-->57  45-->34  46-->21  47-->63

48--> 5  49-->37  50-->18  51--> 8  52-->62  53-->56  54-->20  55-->54

56-->60  57-->19  58-->38  59--> 9  60-->61  61-->55  62-->59  63-->53

请输入逻辑地址(十进制):

765497

本次访问的地址已超出进程的地址空间,系统将产生越界中断!

Press any key to continue

// PageMessage.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

#include<iostream>
#include<iomanip>
using namespace std;

#define pagesize  1024
#define pagetablelength  64

/*系统页表*/
const int pagetable[pagetablelength]={0,42,29,15,45,31,44,43,
                               41,28,1,30,12,24,6,32,
                               14,27,13,46,7,33,10,22,
                               40,2,51,11,39,23,49,50,
                               26,16,25,4,47,17,3,48,
                               52,36,58,35,57,34,21,63,
                               5,37,18,8,62,56,20,54,
                               60,19,38,9,61,55,59,53};



int _tmain(int argc, _TCHAR* argv[])
{
    int logicaladdress=0;
    int pagenum=0;
    int w=0;
    cout<<"系统页号对应块号情况(页号——>块号):
";
    for(int i=0;i<64;i++)
    {        
        cout<<setw(2)<<i<<"-->"<<setw(2)<<pagetable[i]<<"  ";
        if(i%8==7)
            cout<<endl;
    }
    cout<<endl<<"请输入逻辑地址(十进制):
";
    cin>>logicaladdress;

    /*公式:
        物理地址=页号对应的页块*页面大小+页内偏移
        页内偏移=逻辑地址-页面大小*页面数*/


    pagenum=logicaladdress/pagesize;            //页面数

    w=logicaladdress-pagenum*pagesize;            //页面偏移

    if((logicaladdress/pagesize)>pagetablelength)
    {
        cout<<"本次访问的地址已超出进程的地址空间,系统将产生越界中断!
";
        return 0;
    }
    cout<<"对应的物理地址为(十进制):
"<<pagetable[pagenum]*pagesize+w<<endl;
    
    system("pause");
    return 0;
}
原文地址:https://www.cnblogs.com/gd-luojialin/p/7790086.html