admin管理员组

文章数量:1122850

在Windows里面,一个进程拥有4GB的虚拟地址空间,当一个可执行文件在内存中被创建进程时,设定用户空间为2G,内存分布如下:


 

以下地址空间是指用户分区地址空间:

1. 栈区:    栈是位于地址空间的顶端,地址增长方式是从大到小。

2. 堆区:    堆区位于底端+数据区OFFSET+代码段OFFSET,地址增长方式是从小到大。

3. 全局变量区:这个区域分为初始化的部分和未初始化部分,两个部分相邻,这里存储全局变量,常量,静态变量等数据。

4. 代码段: 二进制指令


在32位系统下,如果进程动态分配一个4G的内存空间,会失败,原因是动态分配的内存在用户分区里面的堆上,用户分区需要扣除共享内核分区和NULL指针分区,已经远小于4G了,在用户分区内也要扣除进程本身的代码段,全局区,栈空间,其余的才是堆的大小。只有当分配的空间比堆小的时候,才能成功。


以上是个人理解,如有错误的之处,欢迎拍砖!


本文标签: 概要进程内存Windows