摘自 unix高级环境编程
由于历史原因,C程序一直由下列几部分组成:
• 正文段。这是由C P U执行的机器指令部分。通常,正文段是可共享的,所以即使是经常
执行的程序(如文本编辑程序、 C编译程序、s h e l l等)在存储器中也只需有一个副本,另外,正
文段常常是只读的,以防止程序由于意外事故而修改其自身的指令。
• 初始化数据段。通常将此段称为数据段,它包含了程序中需赋初值的变量。例如, C程
序中任何函数之外的说明:
int maxcount = 99;
使此变量以初值存放在初始化数据段中。
• 非初始化数据段。通常将此段称为 bss段,这一名称来源于早期汇编程序的一个操作符,
意思是“block started by symbol(由符号开始的块)”,在程序开始执行之前,内核将此段初始
化为0。函数外的说明:
long sum[1000] ;
使此变量存放在非初始化数据段中。
• 栈。自动变量以及每次函数调用时所需保存的信息都存放在此段中。每次函数调用时,
其返回地址、以及调用者的环境信息(例如某些机器寄存器)都存放在栈中。然后,新被调
用的函数在栈上为其自动和临时变量分配存储空间。通过以这种方式使用栈, C函数可以递归
调用。
• 堆。通常在堆中进行动态存储分配。由于历史上形成的惯例,堆位于非初始化数据段顶
和栈底之间。
图7 - 3 显示了这些段的一种典型安排方式。
这是程序的逻辑布局—虽然并不要求一个具体
实现一定以这种方式安排其存储空间。尽管如
此,这给出了一个我们便于作有关说明的一种
典型安排。
对于VA X上的 4 . 3 + B S D,正文段从 0位置开
始,栈顶则在0 x 7 fffffff之下开始。在VA X机器上,
堆顶和栈底之间未用的虚地址空间很大。
从图 7 - 3还可注意到末初始化数据段的内容
并不存放在磁盘程序文件中。需要存放在磁盘程
序文件中的段只有正文段和初始化数据段。
size( 1 )命令报告正文段、数据段和 b s s段的长
度(单位:字节)。例如:
第4和第5列是分别以十进制和十六进制表示的总长度
file(1)命令参看FE头部相关信息
nm(1)查看符号信息
objdump(1) 查看反汇编信息<具体用法另查>