linux下objdump命令用法介绍及如何使用objdump命令进行反汇编
2016-12-30 17:57
549 查看
linux下objdump命令的具体选项如下:
linux下objdump命令常见用法举例:
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的信息
如何使用linux下objdump命令对任意一个二进制文件进行反汇编?
可以使用如下命令:
objdump -D -b binary -m i386 a.bin
-D表示对全部文件进行反汇编,-b表示二进制,-m表示指令集架构,a.bin就是我们要反汇编的二进制文件
objdump -m可以查看更多支持的指令集架构,如i386:x86-64,i8086等
另外上面的所有objdump命令的参数同样适用于arm-linux-objdump。
同时我们也可以指定big-endian或little-endian(-EB或-EL),我们可以指定从某一个位置开始反汇编等。
objdump命令是Linux下的反汇编目标文件或者可执行文件的命令,它还有其他作用,下面以ELF格式可执行文件test为例详细介绍:
objdump -f test 显示test的文件头信息
objdump -d test 反汇编test中的需要执行指令的那些section
objdump -D test 与-d类似,但反汇编test中的所有section
objdump -h test 显示test的Section Header信息
objdump -x test 显示test的全部Header信息
objdump -s test 除了显示test的全部Header信息,还显示他们对应的十六进制文件代码
objdump [-a│--archive-headers] [-b bfdname│--target=bfdname] [-C│--demangle[=style] ] [-d│--disassemble] [-D│--disassemble-all] [-z│--disassemble-zeroes] [-EB│-EL│--endian={big │ little }] [-f│--file-headers] [--file-start-context] [-g│--debugging] [-e│--debugging-tags] [-h│--section-headers│--headers] [-i│--info] [-j section│--section=section] [-l│--line-numbers] [-S│--source] [-m machine│--architecture=machine] [-M options│--disassembler-options=options] [-p│--private-headers] [-r│--reloc] [-R│--dynamic-reloc] [-s│--full-contents] [-W│--dwarf] [-G│--stabs] [-t│--syms] [-T│--dynamic-syms] [-x│--all-headers] [-w│--wide] [--start-address=address] [--stop-address=address] [--prefix-addresses] [--[no-]show-raw-insn] [--adjust-vma=offset] [--special-syms] [-V│--version] [-H│--help] objfile...
linux下objdump命令常见用法举例:
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的信息
如何使用linux下objdump命令对任意一个二进制文件进行反汇编?
可以使用如下命令:
objdump -D -b binary -m i386 a.bin
-D表示对全部文件进行反汇编,-b表示二进制,-m表示指令集架构,a.bin就是我们要反汇编的二进制文件
objdump -m可以查看更多支持的指令集架构,如i386:x86-64,i8086等
另外上面的所有objdump命令的参数同样适用于arm-linux-objdump。
同时我们也可以指定big-endian或little-endian(-EB或-EL),我们可以指定从某一个位置开始反汇编等。
objdump命令是Linux下的反汇编目标文件或者可执行文件的命令,它还有其他作用,下面以ELF格式可执行文件test为例详细介绍:
objdump -f test 显示test的文件头信息
objdump -d test 反汇编test中的需要执行指令的那些section
objdump -D test 与-d类似,但反汇编test中的所有section
objdump -h test 显示test的Section Header信息
objdump -x test 显示test的全部Header信息
objdump -s test 除了显示test的全部Header信息,还显示他们对应的十六进制文件代码
相关文章推荐
- 关于如何在Android源码目录中建立自己的C工程,并用mm命令单独进行该C工程模块的编译,以及Android.mk的使用介绍(1)
- 如何使用命令进行Mac和Linux之间的文件传输
- Linux下使用objdump+vim+xxd进行反汇编并修改指令
- linux下objdump命令用法介绍
- linux下如何使用sftp命令进行文件上传和下载
- Linux下使用objdump+vim+xxd进行反汇编并修改指令
- 关于如何在Android源码目录中建立自己的C工程,并用mm命令单独进行该C工程模块的编译,以及Android.mk的使用介绍(2)
- linux下如何使用sftp命令进行文件上传和下载
- 嵌入式 linux下date命令详解以及如何在Makefile中定义宏并在c中进行使用来定义软件版本号
- 基础 Linux 命令用法 - 使用 bc 进行简单运算与进制转换
- Linux如何安装使用pidstat命令以对进程数据进行监控
- 在Linux中如何使用命令进行RS-232串口通信和数据包解析
- linux下如何使用sftp命令进行文件上传和下载
- 简要介绍如何配置与使用 Linux 网络系统的多播IP
- 介绍linux下vi命令的使用
- 如何在Linux中使用cron命令
- 关于Linux Grep命令使用的详细介绍
- 如何使用eclipse进行嵌入式Linux的开发
- 在Linux下使用nc命令进行文件传输收藏
- 如何使用jar命令对java工程进行打包