以32位虚拟地址为例
1.设计原因:
站在设计者的角度看,页表中存有两个地址,一个虚拟地址,一个物理地址,
一个地址在32位机器下大小是4字节,2个地址就是8字节 + 存储权限,我们假设一行页表项大小是10字节。 假设虚拟地址全部都有:2^32个
那么一个进程的页表大小是 2^32 (个) * 10(字节) = 40GB!!!!!
这样一个进程的页表都要40GB,肯定不能这样设计。所以设计者这样设计了一手:
把虚拟地址分成3部分。
2.设计原理
一共是32位分成3部分:第一部分:10个bit位,第二部分:10个bit位,第3部分:12个bit位
第一部分开辟一个页目录,10个bit位满地址也只有2^10(1024)个,一个地址大小为4字节,这一个页目录大小是4kb。页目录项里面存的是二级页表项的地址。
第二部分同理也开辟一个二级页目录,大小同样是4kb。每一个二级页目录项中存的是页框的初始地址。
物理内存里面的基本单元是页框(4kb),一个页框中有很多数据,要访问其中之一的话就需要偏移量,剩下的12个bit位刚好可以“代表” 4kb.
4kb * 4kb = 16mb 16mb远远小于40gb!!!