Linux系统是如何用虚拟内存来欺骗应用程序的?
扫描二维码
随时随地手机看文章
- 一、让有意义的事情变的有意思
- 二、物理内存、虚拟内存
- 三、Linux 中的换页机制
一、让有意义的事情变的有意思
昨天,看到下面这句话,送给您:让有意思的事情变的有意义,让有意义的事情变的有意思!不敢说这是一句人生哲学,但是我们可以从这句话中找到我们做一件事情时的导向。
二、物理内存、虚拟内存
1. 从 x86 硬件角度看
在 x86 平台上,主存储器(也就是我们说说的内存)负责存储指令和数据,它的作用仅次于 CPU。离开了内存,性能再好的 CPU 也无法工作。就像人类的大脑一样,如果没有了记忆功能,再怎么聪明都无法施展。内存被划分为若干个存储单元,从 0 开始编号,一直到最大的那个存储单元。CPU 通过地址总线来定位一个内存的空间,通过数据总线从内存中读取数据、或者向内存中写入数据。我们都知道,同一个 x86 平台的硬件,既可以安装 Windows 操作系统,也可以安装 Linux 操作系统。也就是说,在生产硬件的时候,它并不知道: 在自己的硬件之上,将会运行什么样的程序。也许会有高手直接写一个牛逼的程序,直接来管理各种硬件资源、实现自己特定的功能呢!?不管如何,x86 平台处理器架构定义了自己的一套规则来访问内存。因此,从 x86 平台硬件角度看,只有(物理)内存这个东西,它压根不知道什么是虚拟内存。2. 从操作系统的角度看
操作系统最重要的功能就是:向应用程序屏蔽了各种硬件资源,提供更加友好的接口,让程序开发变得更容易。所以,操作系统会充分利用硬件的各种运行机制,然后进行抽象、包装,面向应用程序开发者提供一个稳定的环境。那么对于内存来说,操作系统向下对物理内存进行管理,向上对应用程序提供虚拟内存。3. 从应用程序开发者的角度看
在很久以前,各种单片机、嵌入式 MCU 上,编写应用程序的时候,经常会面对内存很紧张的情况,这是就要很好的来优化自己的程序,利用有限的硬件资源来实现一些功能。(突然想起多年之前的以为老工程师对我说,面对那么有限的一点资源,都会想哭!)随着硬件的快速发展,这种硬件资源紧张的情况好像很少遇到了,给我们的感觉是:内存我可以随便用,想要多少就 malloc 多少。当然了,操作系统会给出一些限制的,这只是操作系统层面的限制,因为它有自己的考量因素。当应用程序提出申请一块内存空间时,操作系统为了满足应用程序的需求,就会从虚拟内存中“划分”出一块空间,然后把这个空间的开始地址返回给应用程序。因此,从应用程序开发的角度看,我们并不关心物理内存、虚拟内存。只要我 malloc 了,操作系统给我一个足够的空间就行!至于这个空间是从哪里分配的,I don't care!也就是说,应用程序是面向虚拟内存编写的,而不是面向物理内存编写的。当然了,最终存储数据的肯定是物理内存,至于虚拟内存如何与物理内存建立对应的映射关系,这就是由操作系统操心的事情了。每个应用程序只能看到自己的虚拟内存空间,这是一块连续的空间,从而保证了不同应用程序之间的隔离,达到安全目的。三、Linux 中的换页机制
因此老板在对外宣传的时候,就说:我的旅馆很大,有 10000 个房间,欢迎前来入住!
- 旅行团或顾客只能看到这个旅馆的门头和大厅,并不知道旅馆里面的房间布局;
- 旅行团并不会在同一时刻、扎堆的同时来住宿;
虚拟内存 = 对外宣传的 10000 个房间; 物理内存 = 实际的 1000 个房间; 硬盘 = 只有床铺的仓库。当物理内存不够的时候,操作系统把一些物理内存页的内存暂时存储到空间更大、价格更便宜的硬盘上,然后就可以回收这些物理内存继续使用了。
让知识流动起来,越分享,越幸运!
星标公众号,能更快找到我!