转 一条进程的栈区、堆区、数据区和代码区在内存中的映射

一条进程的栈区、堆区、数据区和代码区在内存中的映射
    1>栈区:主要用来存放局部变量, 传递参数, 存放函数的返回地址。.esp 始终指向栈顶, 栈中的数据越多, esp的值越小。
    2>堆区:用于存放动态分配的对象, 当你使用 malloc和new 等进行分配时,所得到的空间就在堆中。动态分配得到的内存区域附带有分配信息, 所以你  能够 free和delete它们。
    3>数据区:全局,静态和常量是分配在数据区中的,数据区包括bss(未初始化数据区)和初始化数据区。
注意:
    1)堆向高内存地址生长;
    2)栈向低内存地址生长;
    3)堆和栈相向而生,堆和栈之间有个临界点,称为stkbrk。

1、一条进程在内存中的映射
    假设现在有一个程序,它的函数调用顺序如下:
    main(...) ->; func_1(...) ->; func_2(...) ->; func_3(...),即:主函数main调用函数func_1; 函数func_1调用函数func_2; 函数func_2调用函数func_3。
    当一个程序被操作系统调入内存运行, 其对应的进程在内存中的映射如下图所示:

 

 

注意:
    1>随着函数调用层数的增加,函数栈帧是一块块地向内存低地址方向延伸的;
    2>随着进程中函数调用层数的减少(即各函数调用的返回),栈帧会一块块地被遗弃而向内存的高址方向回缩;
    3>各函数的栈帧大小随着函数的性质的不同而不等, 由函数的局部变量的数目决定。
    4>未初始化数据区(BSS):用于存放程序的静态变量,这部分内存都是被初始化为零的;而初始化数据区用于存放可执行文件里的初始化数据。这两个区统称为数据区。
    5>Text(代码区):是个只读区,存放了程序的代码。任何尝试对该区的写操作会导致段违法出错。代码区是被多个运行该可执行文件的进程所共享的。   
    6>进程对内存的动态申请是发生在Heap(堆)里的。随着系统动态分配给进程的内存数量的增加,Heap(堆)有可能向高址或低址延伸, 这依赖于不同CPU的实现,但一般来说是向内存的高地址方向增长的。
    7>在未初始化数据区(BSS)或者Stack(栈区)的增长耗尽了系统分配给进程的自由内存的情况下,进程将会被阻塞, 重新被操作系统用更大的内存模块来调度运行。
    8>函数的栈帧:包含了函数的参数(至于被调用函数的参数是放在调用函数的栈帧还是被调用函数栈帧, 则依赖于不同系统的实现)。函数的栈帧中的局部变量以及恢复该函数的主调函数的栈帧(即前一个栈帧)所需要的数据, 包含了主调函数的下一条执行指令的地址。

2、  函数的栈帧
    函数调用时所建立的栈帧包含下面的信息:
    1)函数的返回地址。返回地址是存放在主调函数的栈帧还是被调用函数的栈帧里,取决于不同系统的实现;
    2)主调函数的栈帧信息, 即栈顶和栈底;
    3)为函数的局部变量分配的栈空间;
    4)为被调用函数的参数分配的空间取决于不同系统的实现。

注意:
    1>bss区(未初始化数据段):并不给该段的数据分配空间,仅仅是记录了数据所需空间的大小。
    2>data(初始化的数据段):为数据分配空间,数据保存在目标文件中。

原文地址:http://zqwt.012.blog.163.com/blog/static/120446842010113091137224/

时间: 2024-09-13 09:33:56

转 一条进程的栈区、堆区、数据区和代码区在内存中的映射的相关文章

求解决方案:在数据库数据量很大时(如几百上千万条record),如何查找数据,以及分页显示在页面中。

问题描述 如题,这应该是比较常遇到的情况,希望大家讨论下有哪些解决方案,有简单的代码就最好了. 解决方案 解决方案二:只能数据库分页...解决方案三:请问数据库分页是什么意思?和web里的分页应该不同吧?解决方案四:使用hibernate分页.解决方案五:就是在数据库里就把满足条件的记录的某些行查询出来,不同的数据库sql写法是不一样的,oracle用rownum来分页,sqlserve用top.现在的一些orm如hibernate就可以帮你搞定这些,具体的实现细节不用你去做解决方案六:John

【程序5大区】堆、栈、自由存储区、全局/静态存储区、常量存储区

五大内存分区  在C++中,内存分成5个区,他们分别是堆.栈.自由存储区.全局/静态存储区和常量存储区.  栈,就是那些由编译器在需要的时候分配,在不需要的时候自动清楚的变量的存储区.里面的变量通常是局部变量.函数参数等.  堆,就是那些由new分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般一个new就要对应一个delete.如果程序员没有释放掉,那么在程序结束后,操作系统会自动回收.  自由存储区,就是那些由malloc等分配的内存块,他和堆是十分相似的,不过它是用free

linux-LINUX查看进程,这两条进程分别是啥意思

问题描述 LINUX查看进程,这两条进程分别是啥意思 解决方案 参考. http://zhidao.baidu.com/link?url=-ahSB0ttw9atRfm1DhJTyJ0ygh56jIH9NXsLoQ9mNBCxPzkiu6ZkgnUitbXoNCBqwD2FyCK7dJrw-BXa2cdJpU7vrjvZWPqEYdL40RWIXFO 解决方案二: [root@xxx ~]# ps -ef UID PID PPID C STIME TTY TIME CMD root 1 0 0

c#-C# 内存分几部分啊?堆、栈、静态存储区,还有别的没?

问题描述 C# 内存分几部分啊?堆.栈.静态存储区,还有别的没? 关于内存分类,有一篇关于C++的,讲得很详细,但哪位大神给介绍一下C#的呢,也是五部分吗? 解决方案 首先分为两部分 寄存器和内存(包括缓存) 内存分为两部分 代码和数据 数据分为两部分 静态存储区和运行时存储 运行时存储分为 堆栈 和 堆 静态存储分为 全局静态存储 和 常量 解决方案二: 静态存储区.堆和栈的区别静态存储区.堆和栈的区别静态存储区.堆和栈的区别 解决方案三: 代码区,堆,栈,静态区. 解决方案四: http:/

c-C/C++内存分几部分啊?堆、栈、静态存储区,还有别的没?

问题描述 C/C++内存分几部分啊?堆.栈.静态存储区,还有别的没? C/C++ 的内存分几部分啊?堆.栈.静态存储区,还有别的没?每部分的具体作用是什么? 解决方案 首先分为两部分 寄存器和内存(包括缓存) 内存分为两部分 代码和数据 数据分为两部分 静态存储区和运行时存储 运行时存储分为 堆栈 和 堆 静态存储分为 全局静态存储 和 常量 解决方案二: 我自己画了个图,可以参考下. 解决方案三: 静态存储分为 全局静态存储 还有文字常量区吧, 解决方案四: http://www.cnblog

Oracle内存结构详解(六)UGA、CGA及软件代码区

1.UGA (The User Global Area) PGA是一段包含一个Oracle服务或后台进程的数据和控制信息的内存.PGA的大小依赖与系统的配置.在专用服务(Dedicated Server)模式下,一个服务进程与一个用户进程相关,PGA就包括了堆空间和UGA.而UGA(User Global Area用户全局区)由用户会话数据.游标状态和索引区组成.在共享服务(MTS)模式下,一个共享服务进程被多个用户进程共享,此时UGA是Shared Pool或Large Pool的一部分(依赖

从数组中随机取x条不重复数据的JS代码

 这篇文章主要介绍了从数组中随机取x条不重复数据的JS代码,有需要的朋友可以参考一下 工作中经常遇到有关数组的一些操作    1. 从数据中随机取x条不重复的数据 (PS:下面的S.each是KISSY.each方法,大家可以改为for循环)   代码如下: /* 从数组arr中随机取x条不重复的数据  */  function myRand(arr,num){     var newArr = [];     rand(num);    //随机 x 个       function rand

堆和栈的问题-内存中的"堆"和"栈"的知识

问题描述 内存中的"堆"和"栈"的知识 Public static void changeStr(String str){ str="welcome"; } Public static void main(String[] args) { String str="1234"; changeStr(str); System.out.println(str); } 以这个体为例谁能给我解释一下关于 "堆",&q

hql-关于Hql语句,这条语句为什么查不出数据

问题描述 关于Hql语句,这条语句为什么查不出数据 hql = "from A a where a.timeDate <= "+time+" and a.name not in (select b.name from B b)"; super.findTopByHql(hql, 20); 这条语句有没有问题啊,为什么查不到数据 解决方案 检查下日期有没有引号,是否合法 最好是使用参数 hql = "from A a where a.timeDate