Linux-readelf,objdump

objdump查看目标文件的信息

objdump查看目标文件或者可执行目标文件的构成的gcc工具

常见选项:

objdump -x obj:以某种分类信息的形式把目标文件的数据组成输出;<可查到该文件的的所有动态库>

objdump -t obj:输出目标文件的符号表()

objdump -h obj:输出目标文件的所有段概括()

objdump -j ./text/.data -S obj:输出指定段的信息(反汇编源代码)

objdump -S obj:输出目标文件的符号表()  当gcc -g时打印更明显

objdump -j .text -Sl stack1 | more

-S 尽可能反汇编出源代码,尤其当编译的时候指定了-g这种调试参数时,

   效果比较明显。隐含了-d参数。

-l 用文件名和行号标注相应的目标代码,仅仅和-d、-D或者-r一起使用

  使用-ld和使用-d的区别不是很大,在源码级调试的时候有用,要求

  编译时使用了-g之类的调试编译选项。
 
-j name 仅仅显示指定section的信息


例:objdump -h 查看文件的所有段在这里插入图片描述
例:objdump -s 显示各个段的内容
在这里插入图片描述
判断section放了哪些变量

elf

中间文件的格式:
在这里插入图片描述
可执行文件的格式:
在这里插入图片描述

readelf 用于显示 elf 格式文件信息

常见选项:


```c
`-a 
--all 显示全部信息,等价于 -h -l -S -s -r -d -V -A -I. 

-h 
--file-header 显示elf文件开始的文件头信息. 

-l 
--program-headers  
--segments 显示程序头(段头)信息(如果有的话)。 

-S 
--section-headers  
--sections 显示节头信息(如果有的话)。 

-g 
--section-groups 显示节组信息(如果有的话)。 

-t 
--section-details 显示节的详细信息(-S的)。 

-s 
--syms        
--symbols 显示符号表段中的项(如果有的话)。 

-e 
--headers 显示全部头信息,等价于: -h -l -S 
`

例:readelf -h显示elf header信息
在这里插入图片描述
section header放着各个段的详细信息,bss虽然不占空间,但详细信息都在里面
entry point address 程序入口地址
例:readelf -s 查看符号表
在这里插入图片描述
local符号带static 只在本文件使用
具体:符号和符号解析

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值