对于每个进程而言都能看到
4G
的内存,一个页是
4K
,一共有
4G/4K=2^20
个页。每个进程中都有自己的一个页目录(一级页表),这个页目录可以管辖
1024
个二级页表,充足情况下进程会有
1024
个二级页表。那么这
1024
个页对于用户来说就不用了,可以从
2^20
个页表中去除,实际需要管理的页的个数就是
2^20-1024=1023*1024
个页。又因为我们有
1024
个二级页表,每个二级页表可以管理
1024
个页,理论上可以管理
1024*1024
个页,但是我们已经知道实际只需要管理
1023*1024
个页,也就是说我们可以腾出一个二级页表示空闲的,因为页目录和二级页表的存储格式是一样的,我们可以把这个二级页表替换成页目录,这样实际就是一个页目录加上
1023
个二级页表形成一个
1024
个页组成的
4M
大页。
如下图,0~1023是1024个二级页表,那么也就是1024个页,那么必然有一个二级页表来管理这1024个页,不妨令红色的这个二级页表管理这1024个页,那么它其实就是页目录,不妨令编号为页目录基值的那个二级页表作为页目录。