四季风 发表于 2015-7-20 23:16:51

汇编语言中的,数据段,栈段,代码段

      大家好,汇编语言中的,数据段,栈段,代码段,它们在内存中是连续的吗,或者说各段之间是连续存储的吗?


      帮忙解答一下,谢谢!

小甲鱼的二师兄 发表于 2015-7-20 23:42:39

1、高位地址:栈(存放着局部变量和函数参数等数据),向下生长(可读可写可执行)

2、堆(给动态分配内存是使用),向上生长(可读可写可执行)

3、数据段(保存全局数据和静态数据)(可读可写不可执行)

4、地位地址:代码段(保存代码)(可读可执行不可写)



代码段就是存储程序文本的,所以有时候也叫做文本段,指令指针中的指令就是从这里取得。这个段一般是可以被共享的,比如你在Linux开了2个Vi来编辑文本,那么一般来说这两个Vi是共享一个代码段的,但是数据段不同(这点有点类似C++中类的不同对象共享相同成员函数)。

数据段是存储数据用的,还可以分成初始化为非零的数据区,BSS,和堆(Heap)三个区域。初始化非零数据区域一般存放静态非零数据和全局的非零数据。BSS是Block Started by Symbol的缩写,原本是汇编语言中的术语。该区域主要存放未初始化的全局数据和静态数据。还有就是堆了,这个区域是给动态分配内存是使用的,也就是用malloc等函数分配的内存就是在这个区域里的。它的地址是向上增长的。

      最后一个堆栈段(注意,堆栈是Stack,堆是Heap,不是同一个东西),堆栈可太重要了,这里存放着局部变量和函数参数等数据。例如递归算法就是靠栈实现的。栈的地址是向下增长的。具体如下:

========高地址   =======

程序栈      堆栈段

向下增长

=======“空洞”=======

向上增长


------          数据段
BSS
------
非零数据

=========低地址   =======

================

代码         代码段

================

需要注意的是,代码段和数据段之间有明确的分隔,但是数据段和堆栈段之间没有,而且栈是向下增长,堆是向上增长的,因此理论上来说堆和栈会“增长到一起”,但是操作系统会防止这样的错误发生,所以不用过分担心。

四季风 发表于 2015-7-21 11:52:27

多谢,我明白了一些{:1_1:}

fast 发表于 2015-7-21 19:08:49

继续努力,加油学习

不二如是 发表于 2020-3-29 10:48:15

需要注意的是,代码段和数据段之间有明确的分隔,但是数据段和堆栈段之间没有,而且栈是向下增长,堆是向上增长的,因此理论上来说堆和栈会“增长到一起”,但是操作系统会防止这样的错误发生,所以不用过分担心。

1、高位地址:栈(存放着局部变量和函数参数等数据),向下生长(可读可写可执行)

2、堆(给动态分配内存是使用),向上生长(可读可写可执行)

3、数据段(保存全局数据和静态数据)(可读可写不可执行)

4、地位地址:代码段(保存代码)(可读可执行不可写)



代码段就是存储程序文本的,所以有时候也叫做文本段,指令指针中的指令就是从这里取得。这个段一般是可以被共享的,比如你在Linux开了2个Vi来编辑文本,那么一般来说这两个Vi是共享一个代码段的,但是数据段不同(这点有点类似C++中类的不同对象共享相同成员函数)。

数据段是存储数据用的,还可以分成初始化为非零的数据区,BSS,和堆(Heap)三个区域。初始化非零数据区域一般存放静态非零数据和全局的非零数据。BSS是Block Started by Symbol的缩写,原本是汇编语言中的术语。该区域主要存放未初始化的全局数据和静态数据。还有就是堆了,这个区域是给动态分配内存是使用的,也就是用malloc等函数分配的内存就是在这个区域里的。它的地址是向上增长的。

      最后一个堆栈段(注意,堆栈是Stack,堆是Heap,不是同一个东西),堆栈可太重要了,这里存放着局部变量和函数参数等数据。例如递归算法就是靠栈实现的。栈的地址是向下增长的。具体如下:

========高地址   =======

程序栈      堆栈段

向下增长

=======“空洞”=======

向上增长


------          数据段
BSS
------
非零数据

=========低地址   =======

================

代码         代码段

================

页: [1]
查看完整版本: 汇编语言中的,数据段,栈段,代码段