篇首语:本文由编程笔记#小编为大家整理,主要介绍了《Linux从0到99》七 进程地址空间相关的知识,希望对你有一定的参考价值。
地址空间(address space) 表示任何一个计算机实体所占用的内存大小。比如外设、文件、服务器或者一个网络计算机。地址空间包括物理空间以及虚拟空间。
如果没有地址空间,我们访问的永远都是真实的物理地址,那么这样会有两个弊端:
通过地址空间所提供的地址,然后在通过页表转化为物理内存,拿到数据和内容。
分页式内存管理的虚拟地址组成:页号+页内偏移
页号:页表中页表项的编号。
页内偏移:具体一个变量首地址相较于内存页起始位置的偏移量。
主要功能:映射虚拟地址与物理地址的关系/提供内存访问控制
访问方式:通过虚拟地址中的页号和页内偏移通过页表找到进程中数据在物理内存上的位置。
页表组成:
页号 | 物理块号 |
---|---|
… | … |
2 | 5 |
1 | 6 |
0 | 7 |
物理内存块号*物理内存块大小+虚拟地址中偏移量=物理内存地址
假设内存大小为4G,页大小是4096字节,则意味着页号的位是虚拟地址的高二十位,低十二位为页内偏移。(4G=2^32, 4096=2^12, 4G/4096=2^20)
分页式内存内存管理的优点: 将物理内存进行分块管理,通过页表映射虚拟地址与物理内存关系实现数据的离散式存储,提高内存利用率。
虚拟地址组成:段号+段内偏移
访问方式:通过段表映射进程数据集在物理内存中的位置
段表
段号 | 物理段起始地址 |
---|---|
… | … |
进程首先通过虚拟地址中的信息找到段号,通过段号在段表中找到在物理内存中的起始位置,然后加上段内偏移,就可以得到进程中某个数据集的物理内存地址。
分段式内存管理的优点: 使程序员对内存的管理更加方便,将内存段分为了代码段,初始化全局段等等段,什么变量就在什么段申请空间。
段页式内存管理:顾名思义,就是将分页式与分段式结合起来的一种内存管理方式。
虚拟地址组成: 段号+段内页号+页内偏移
段表: 段号 段内页表起始地址
页表: 页号 物理块号
访问原理: 先将进程数据分成若干段,为每个段进行命名,再将若干段分成若干页
访问方式: 进程首先是通过自己的分段找到在段表中相应的段号,然后通过该段表项找到页表始址,通过页表项中的物理块号和页内偏移访问物理内存空间。