操作系统(页表)

分页和页表

一般来说,我们在用C语言和汇编语言等编写程序时能直接访问的地址都是 逻辑地址,所有的逻辑地址组成的地址空间称为 逻辑地址空间, 然而逻辑地址逻辑地址不是真正的内存地址,假如我用C语言去访问地址为1000的内存中的内容,其实真正访问的一般不会是是内存中地址为1000处的内容,而是操作系统帮我们做了映射,这个1000映射的实际地址是不固定的,所以操作系统需要去把映射记录下来,当我们每次去访问的时候操作系统会去查这个记录表找到我们真正要访问的数据所存在的内存地址。
举一个例子

我们写了一个程序,和简单,只有两条语句
int a = 5;
printf("%d",a);
但我们运行代码的时候,操作系统就会创建一个进程,这个进程就是执行我们的的代码的程序,把它列为一个进程是操作系统为了管理它,这时它有一个逻辑地址空间,并且它是这个逻辑地址空间的唯一主人,
当它执行 int a = 5 这条语句时,在内存中某个地方保存内容 5,在C语言中你可以通过 &a 拿到它存放的地址,然而这个地址只是逻辑地址,它在内存中真正的地址你是看不到的,操作系统也不想让你看到。当我们使用第二条语句输出 a 时, 就相当于发起了访问的请求,请求的地址是逻辑地址,操作系统通过查找记录表找到了5所在的真实地址程序才能够访问并输出正确的结果 5

这个记录表就是我们的 页表,我们知道内存的最小寻址单位是字节(byte),然而我们如今的内存8G起步,如果每一个字节都存一条记录可能我们的内存都存不下,跟别说还要存放我们的程序了,所以一般会把一段一定长度连续的内存地址空间称为一页, 这就是 分页, 分页的大小在逻辑地址空间和物理地址空间是一样的,这样方便寻址。

最后献上一张图
在这里插入图片描述

おすすめ

転載: blog.csdn.net/tblwbr520/article/details/121879386