现在的位置: 首页 > 综合 > 正文

xcode反汇编调试iOS模拟器程序(一)查看反汇编

2013年10月17日 ⁄ 综合 ⁄ 共 680字 ⁄ 字号 评论关闭

iOS模拟器程序的实质就是Mac OS X程序,只不过它需要以模拟器为载体来运行显示。故它的反汇编代码指令都是x86 CPU的,不是真机上的arm指令。

研究模拟器程序的反汇编有两个目的,或叫做好处:

一是为了研究深入到iOS系统的类库,你可以较容易地发现私有API,以及看到系统的实现。

二是,很直接地,模拟器调试比真机快。而且,相信大多数人更懂x86指令,各类高校教材的汇编教程都不是arm指令的吧。

首先问题是如何看到反汇编代码:

操作:Xcode顶部菜单->Product->Debug Workflow->Show Disassembly When Debugging打钩

如果是在调试的过程中打钩,则调试窗口会立刻更新显示反汇编代码,如图:

以上主要是为了看到自己写的代码的反汇编情况,当调试进入不是自己写的代码(没有debug symbol)时,无论是否对这个选项打钩,都会显示成反汇编。

例如,在gdb/lldb调试中,break状态下输入

b -[UIView addSubview:]

再continue之后,如果有发生addSubview操作,不论是自己写的还是系统操作的,都会进入反汇编断点:

转载请注明出处:http://blog.csdn.net/hursing

xcode反汇编调试iOS模拟器程序
(一)查看反汇编
(二)看懂反汇编
(三)查看Objective-C函数与参数
(四)自动断点应用之NSNotificationCenter
(五)调试objc_msgSend函数
(六)函数出入口处的处理与局部变量
(七)Debug与Release的区别

(八)反汇编自己的代码来掌握规则

【上篇】
【下篇】

抱歉!评论已关闭.