S.l.e!ep.¢%

像打了激速一样,以四倍的速度运转,开心的工作
简单、开放、平等的公司文化;尊重个性、自由与个人价值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

gdb反汇编

Posted on 2011-04-02 20:37 S.l.e!ep.¢% 阅读(1174) 评论(0)  编辑 收藏 引用 所属分类: Unix

* 反汇编一个函数
disass func_name


*反汇编一段内存地址, 第1个参数是起始地址,第2个是终止地址
disassemble 0×0 0×10


info line 命令来映射一个源码行到程序地址,

然后使用命令disassemble显示一个地址范围的机器指令。


例1. 查看main函数从哪里开始

(gdb) info line main
Line 34 of “rank.c” starts at address 0×804847f
   and ends at 0×8048493 .

例2. 
(gdb) info line *0×804847f
Line 34 of “rank.c” starts at address 0×804847f
   and ends at 0×8048493 .


info line会修改 x/i 命令的默认的起始地址


* disassemble 

不带参数,默认的反汇编范围是 所选择帧的pc附近的函数
单个参数, 就是pc, 当然也可以是函数名,因为函数名 也是一个 地址; 这样范围就是该pc附近的函数
两个参数,就是内存地址范围


* set disassembly-flavor intel  

将汇编指令格式 设置为intel格式,默认是att
(gdb) show disassembly-flavor
The disassembly flavor is “att”.


* 使用x查看反汇编指令
x/3i $pc
显示pc开始的3条指令


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理