1、目标文件的格式
目标文件就是源代码编译后但未进行链接的那些中间文件(例如windows下的.obj文件,Linux下的.o文件)。从广义的角度看,目标文件和可执行文件的格式其实几乎时一样的,在Windows下,将它们统称为PE-COFF文件格式;在Linux下,将他们统称为ELF文件。其实,除了目标文件和可执行文件按照可执行文件格式存储,还有动态链接库和静态链接库也是按照可执行文件格式存储。
2、ELF文件结构布局
首先,先来一段示例代码:#include<stdio.h>
//test.o文件
int gval_init = 84;
int gval_uninit;
void fun(int i)
{
printf("%d\n", i);
}
int main()
{
static int val1 = 85;
static int val2;
int a = 1;
int b;
return a;
}
首先编译文件:gcc -c test.c 只编译不链接
然后查看文件内部结构:objdump -h test.o
显示如下:
由此可以画出此文件的ELF文件布局:
由图可知:ELF文件中除了有
代码段:存放代码,可通过ojdump -s -d test.o 命令查看
数据段:初始化的全局变量和局部静态变量
BSS段:未初始化的全局变量和局部静态变量
只读数据段(.rodata)
注释信息段(.comment)
堆栈提示段(.note.GUN-stack)
ELF文件头部可通过readelf -h test.o查看,如下图所示: