【面经】【转】C程序的内存布局

时间:2022-05-03 08:48:42

【面经】【转】C程序的内存布局

一个C语言程序一直以来都是由以下5个段组成:

1、代码段(text segmrnt):存放CPU执行的机器指令,通常情况下,代码段是可共享的,使其可共享的目的是对于频繁被执行的程序,只需要在没存中有有一份拷贝即可,比如文本编辑器,c编辑器,shell等等。另外,代码段也通常是只读的,使其只读的原因是防止一个程序意外地修改了它的指令。

2、初始化数据段/数据段(initialized data segment/data segmrnt): 该段包括了在程序中明确被初始化的变量。

3、未初始化数据段/bss段(uninitialized data segment/"bss" segment):bss 这个叫法是根据一个早期的汇编运算符而来,这个运算符标志着一个块的开始(stood for "block starded by symbol")。在程序开始执行之前,bss段的数据被kernel初始化为0或者空指针。

4、栈段(stack):每次当一个函数被调用,该函数的返回地址和一些关于caller的信息,比如某些寄存器的内容,将被首先存储到栈段。然后这个被调用的函数再为它的自动变量和临时变量在栈段上分配空间。这就是C如何实现函数的递归调用。每次一个递归函数调用其本身,一个新的栈框架就会被使用,这样这个新实例栈里的一组变量就不会和该函数的另一个实例栈里面的变量互相干扰。

5、堆段(heap):用于动态内存分配。一直以来,堆在内存中的位置是介于bss段和栈段之间。

运行在Inter x86处理器上的linux,代码段从地址开始往上,栈底从地址往下(在这个特定的表示结构中,栈段从高地址向低地址扩展)。在堆顶和栈顶之间的虚拟地址空间是很大的(这保证了2个段不会互相干扰)。