进程地址空间

地址空间

虚拟地址空间和进程地址空间的区别

虚拟地址空间是操作系统给进程提供的一个完整的虚拟内存环境,包括内存内核空间和用户空间;而进程地址空间是进程实际使用的那部分虚拟地址空间,只有用户空间。

每个进程地址空间都是虚拟地址空间的一个实例,虚拟地址空间强调整个虚拟内存的管理,包括动态分配、分页和映射等,进程地址空间更关注进程如何使用这些虚拟的地址空间。

进程地址空间

mm_struct

Linux内核中的一个结构体,用于管理进程虚拟地址空间中的那些数据结构。(task_struct中包含mm_struct指针,指向该进程的内存管理结构)

在 Linux 内核中, mm_struct 包含了以下信息:

  1. 页表(Page tables):用于将虚拟地址映射到物理地址。
  2. 虚拟内存区域(Virtual memory areas, VMAs):描述进程地址空间中的不同区域,如代码段、数据段、堆、栈等。
  3. 内存权限和属性:定义了不同内存区域的访问权限,例如可读、可写、可执行等。
  4. 内存分配策略:描述了进程如何分配和管理内存,包括堆和栈的增长方向。
  5. 文件映射(File mappings):如果进程映射了文件到其地址空间,这些信息也会被记录在 mm_struct 中。

为什么要有进程地址空间?

1、让父子进程可以用统一的视角看待内存。

(父子进程都分配了一个大小相同的进程地址空间,进程地址空间的区域划分是确定的,堆栈、代码区等,子进程可以将父进程的代码数据在虚拟内存里的安排直接拷贝过来)

2、设置进程地址空间可以让我们访问内存的时候,增加一个转换的过程(虚拟地址通过页表到物理地址的映射)。

在转换过程中,系统可以对寻址请求进行审查,一旦访问异常,直接拦截,该请求不会到达物理内存,保护物理内存。

3、进程地址空间和页表的存在,将进程管理模块和内存管理模块进行解耦合,独立开来。

相关推荐
青梅橘子皮9 小时前
Linux---开发工具(2)(makefile、进度条、git、gdb)
linux·运维·服务器
剑神一笑9 小时前
Linux less 命令深度解析:从源码看分页器的设计智慧
linux·运维·less
IT大白鼠9 小时前
Dirty Frag漏洞深度分析:Linux内核页缓存污染漏洞的技术原理与安全防护
linux·安全·dirty frag漏洞
李白你好9 小时前
Linux 本地提权工具支持Linux 内核和 Polkit 漏洞
linux·运维·服务器
陳10309 小时前
Linux:System V IPC
linux·运维·服务器
aFakeProgramer10 小时前
在Ubuntu系统格式化SD卡,单分区/双分区
linux·运维·ubuntu
键盘上的GG小怪兽GG10 小时前
Debian 安装CUPS操作
linux·服务器·debian
Irene199110 小时前
Windows 11 WSL Ubuntu 环境:实际安装 Hadoop 踩坑实录
linux·hadoop·ubuntu
手可摘星辰的少年10 小时前
Ext2数据块寻址原理:直接块、间接块到三级间接块
linux
Irene199110 小时前
nano 和 vim(Linux 默认安装)的区别(文本编辑器 vs 专业编辑器)
linux·vim·nano