32位进程地址空间

对于一个进程,其空间分布如下图所示:
在这里插入图片描述
保留区: 位于地址空间的最低部分(大概100来M),未赋予物理地址。任何对它的引用都是非法的,用于捕捉使用空指针和小整型值指针引用内存的异常情况。会放些动态链接库等。

程序段: 代码段也称正文段或文本段,通常用于存放程序执行代码(即CPU执行的机器指令)。

初始化过的数据(Data Segment): 用于存放程序中已初始化且初值不为0的全局变量和静态局部变量。

未初始化数据(BSS): 段中存放未初始化的全局变量和静态局部变量、初始值为0的全局变量和静态局部变量(依赖于编译器实现)

堆区(stack): 堆用于存放进程运行时动态分配的内存段,可动态扩张或缩减。

共享区(shared space): 堆和栈共享的区域。

栈区(heap): 栈又称堆栈,由编译器自动分配释放,行为类似数据结构中的栈。

环境变量、命令行参数: 存放环境变量、命令行参数信息。

内核空间(kernel space): 内核总是驻留在内存中,是操作系统的一部分。内核空间(3G-4G)为内核保留,不允许应用程序直接读写该区域的内容或直接调用内核代码定义的函数。

猜你喜欢

转载自blog.csdn.net/gamekit/article/details/105038904