进程地址空间是什么为什么要存在地址空间验证地址空间的基本排布
进程地址空间是什么进程地址空间不是物理地址,是一种虚拟地址,由操作系统提供。进程地址空间本质是进程看待内存的方式,抽象出来的一个概念,内核中用一个结构体mm_struct表示,这样每个进程都认为自己独占系统内存资源。
在进程控制块task_struct中有一个mm_struct结构体指针,指向一个mm_struct结构体,这个结构体里面完成对各个数据区域的划分,然后通过页表映射到物理内存上。
区域划分本质:将线性地址空间划分成为一个一个的area,[start, end]
虚拟地址本质:在[start, end]之间的各个地址叫做虚拟地址。
1.如果进程直接访问物理内存,那么我们看到的地址就是物理地址。c语言中可以用指针访问地址,如果指针越界了,有可能直接访问到另一个进程的代码和数据,这样的话进程的独立性无法保证。 因为物理内存暴漏,有可能有恶意程序直接通过物理地址进行内存数据的篡改。所以虚拟地址存在的第一个意义是保护物理内存,不受任何进程的直接访问,这样操作系统就可以在虚拟到物理之间转化的时候方便进行合法性校验。
2.将内存管理和进程管理进行解耦
3.让每个进程以同样的方式来看待代码和数据。
#include#include int g_unval; // 未初始化全局变量 int g_val = 100; // 已初始化全局变量 int main(int argc, char* argv[], char* env[]) { printf("code addr : %pn", main); const char* p = "hello world"; printf("read only : %pn", p); printf("global val : %pn", &g_val); printf("global uninit val : %pn", &g_unval); char* q = (char*)malloc(10); printf("heap addr : %pn", q); printf("stack addr : %pn", &p); printf("stack addr : %pn", &q); printf("args addr : %pn", argv[0]); printf("args addr : %pn", argv[argc-1]); printf("env addr : %pn", env[0]); return 0; }



