• 进程地址空间(Linux虚拟内存机制)


    在这里插入图片描述

    本章理论基于32位平台的Linuxkernel 2.6.32版本内核

    一.Linux进程地址空间的结构

    • 为了保证内存安全,现代操作系统不允许应用程序(进程)直接访问物理内存空间

    • 一般来说,操作系统和编译器会给每一个进程设置一个独立的虚拟内存空间一张映射页表,虚拟内存空间称为进程地址空间,虚拟内存地址通过特定的映射关系与物理内存地址建立联系

    • Linux的进程地址空间从0x00000000 ~ 0xffffffff进行编号,结构如下:在这里插入图片描述

    • 进程中的指令想要访问物理内存,就必须借助虚拟内存地址进行映射,进程的虚拟地址与物理内存通过页表进行映射:在这里插入图片描述

    • 在应用层视角中,应用程序代码中的变量和函数(数据)的内存地址以及指令本身的内存地址全部都是虚拟内存地址!!!所有的这些虚拟内存地址以及它们与物理内存地址的映射关系在应用程序编译时就已经确定了,因此进程的虚拟内存机制本质上是操作系统和编译器协同形成的一种内存管理机制

      • CPU内部在执行指令的时候,其使用的内存地址也是虚拟内存地址

    二.Linux管理进程地址空间的方式

    • 每一个进程都有自己独立的进程地址空间映射页表
    • Linux内核中,进程地址空间由一个struct mm_struct来维护,每个进程的PCB结构体(进程控制块)都会指向一个struct mm_struct结构体:在这里插入图片描述
    • struct mm_struct结构体维护进程地址空间的具体方式类似于用指针来维护地址区间:在这里插入图片描述
    • 当内存中加载了多个进程时,操作系统中就会存在多个struct mm_struct结构体和映射页表,因此Linux进程地址空间的本质是操作系统中的struct mm_struct结构体和映射页表构成的内核数据结构

    三.Linux进程使用物理内存的模型

    • Linux进程的PCB(task_struct)和进程地址空间(mm_struct)的存在形式:
      在这里插入图片描述
    • 进程指令集访问物理内存的方式:
      在这里插入图片描述

    四.进程地址空间的存在意义

    1. 借助映射页表操作系统可以拒绝应用进程的非法访问内存的请求,保证了计算机系统的内存安全
    2. 在操作系统的设计意义上,虚拟内存机制使得操作系统的内存管理模块进程管理模块完成了解耦合,当内存管理算法需要调整时,不会影响到进程管理模块的设计(只需修改映射页表中的物理地址即可),同样,当进程管理模块需要重新设计时,不会影响到内存管理模块
    3. 虚拟内存机制其实是一种物理内存的延迟分配策略,当进程PBC指令集被加载到内存中后,操作系统不会立即为该进程中的对象分配物理内存(即使进程中每个对象都有一个虚拟地址),只有当进程对某个对象进行读写操作时,操作系统才会通过页表映射为对象分配物理内存,这种内存的延迟分配策略提高了各进程并发执行过程中计算机内存的使用效率
    4. 由于进程虚拟地址空间的存在,在应用程序的视角中,各对象的内存地址都是有序地,紧凑地排布的,使得开发人员可以更方便地进行内存操作,同时操作系统也可以更方便地对进程使用内存的情况进行监视和管理,实现物理内存的即时分配和释放.
      在这里插入图片描述
  • 相关阅读:
    C++s简单实现Scoket编程
    解决requests库中的期限处理问题:从404到异常再到修复
    Kali Linux渗透测试的艺术
    算法设计与分析-0/1背包问题
    Chrome开发者模式去除时间轴
    「微前端实践」使用Vue+qiankun微前端方案重构老项目的本地验证
    说一下 TCP/IP 协议?以及每层的作用?
    看完这篇,还不懂JAVA内存模型(JMM)算我输
    PHPstudy安装redis扩展
    【Postman-windows-9.12.2版本安装与汉化】
  • 原文地址:https://blog.csdn.net/weixin_73470348/article/details/132819628