虚拟地址空间
在早期的计算机中,程序是直接运行在物理内存上的,而直接使用物理内存,通常都会面临以下几种问题:
- 内存缺乏访问控制,安全性不足
- 各进程同时访问物理内存时,可能会产生访问内存空间重叠的现象,没有独立性
- 物理内存极小,而并发执行进程所需又大,容易导致内存不足
- 进程所需空间不一,容易导致内存碎片化问题。
基于以上几种原因,Linux通过 mm_struct
结构体来描述了一个虚拟的,连续的,独立的地址空间,也就是我们所说的虚拟地址空间。
原理: 当程序被载入内存时,向其呈现出比实际拥有的地址空间大得多的内存——虚拟地址空间,让程序误认为自己目前独占电脑内存,能够占用电脑所有的内存,访问所有内存地址,同时建立虚拟地址与物理地址之间的映射。这就允许多个程序可以同时运行且各个程序之间能够访问的物理内存区域不重叠,也杜绝了程序直接操作地址的风险,同时也提高物理地址的使用效率。
值得注意的是,在建立了虚拟地址空间后,并没有立刻分配实际的物理内存,而是当进程需要实际访问内存资源的时候,才由内核的 请求分页机制
产生 缺页中断
,这时才会建立虚拟地址和物理地址的映射,调入物理内存页;如果此时物理内存已经耗尽,则根据内存替换算法淘汰部分页面至物理磁盘中。通过这种方法,就能够保证我们的物理内存只在实际使用时才进行分配,避免了内存浪费的问题。