Linux_目标文件里有什么?

本文深入探讨了Linux下的目标文件格式ELF,通过一段示例代码的编译过程,详细解析了ELF文件的布局,包括代码段、数据段、BSS段及只读数据段等关键部分。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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查看,如下图所示:
从上面输出的结果可以看到,ELF 的文件头中定义了ELF魔数、文件机器字节长度、数据存储方式、版本、运行平台、ABI版本、ELF重定位类型、硬件平台、硬件平台版本、入口地址、程序头入口和长度、段表的位置和长度及段的数量等

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值