本文主要介绍下源码探索的三种方法
- 1、
符号断点
直接跟流程 - 2、通过
按住control
+step into
- 3、汇编跟流程
下面详细讲下这三种方法是如何查找到函数
所在的源码库
,以alloc
为例,都在libobjc.A.dylib
Apple source中搜索objc
中
1、符号断点
直接跟流程
-
通过下
alloc
的符号断点-
选择断点
Symbolic Breakpoint
-
符号断点中输入
alloc
-
-
main
中的CJLPerson
处 加一个断点
在走到这部分断点之前,需要关闭上面新增的符号断点,原因是因为alloc的调用有很多,如果开启了就不能准确的定位到CJLPerson
的alloc
方法
以下为符号断点的关闭状态
-
运行程序, 断在CJLPerson部分
-
打开
alloc符号断点
,断点状态为
-
继续执行
以下为alloc符号断点断住的堆栈调用情况,从下图可以看出 alloc 的源码位于
libobjc.A.dylib
库(需要去Apple 相应的开源网址下载 objc源码进行更深入的探索)
-
2、通过按住control
+step into
-
main
中的CJLPerson
处 加一个断点,运行程序,会断在CJLPerson
位置
-
按住
control
键,选择step into
⬇️键
-
进去后,显示为以下内容
-
再下一个
objc_alloc
符号断点,符号断点后显示了objc_alloc
所在的源码库
(需要去Apple 相应的开源网址下载 objc源码进行更深入的探索)
3、汇编跟流程
-
main
中的CJLPerson
处 加一个断点,运行程序,会断在CJLPerson
位置
<LGPerson: 0x6000000104e0> - 0x6000000104e0 - 0x7ff7b7215990
<LGPerson: 0x6000000104e0> - 0x6000000104e0 - 0x7ff7b7215988
解析:开辟的内存空间是一样的(alloc开辟指针地址),但是p1,p2,p3的地址不同
-
xcode 工具栏 选择
Debug
-->Debug Workflow
-->Always Show Disassembly
,这个 选项表示 始终显示反汇编 ,即 通过汇编 跟流程
-
按住
control
,点击step into
⬇️键,执行到下图的callq ,对应 objc_alloc
-
按住
control
,点击step into
⬇️键进入,看到断点断在objc_alloc
部分