首先以Person
对象为例。我们知道创建方法为[[Person alloc] init];
,那么alloc和init在底层做了哪些工作?是怎么实现的呢?
我们首先想到的就是按住command
点击alloc方法跳转进去看下实现流程。这时我们会发现alloc
的底层实现源码我们看不了了,真是太尴尬了。那怎么办呢?这时候就需要下载objc源码objc4-781方便我们进一步探究。
但是我们打开objc4-781会发现里面的方法太多了,我们又如何快速定位alloc实现源码的地方呢?
下面就以alloc
为例介绍快速定位源码位置的三种方法:
1.直接代码打断点定位:
首先我们在
alloc
方法前面打断点,然后按住control
键,会看到控制栏↓箭头出现了变化,多次点击后会看到如图1所示,找到了objc_alloc
方法。此时接下来我们可以继续点击↓箭头往下走,就能定位到如图2所示的方法
此时我们在
_objc_rootAllocWithZone
前面打个断点,按住control
点击↓箭头准备step into
继续跟进此方法的流程时,突然发现没有进去,直接往下走到了alloc
那一行,这是为什么呢?暂时先不管,继续跳转,最终发现又回到了_objc_rootAllocWithZone
方法这一行,说明_objc_rootAllocWithZone
走了两次,为什么会走两次?这两次的过程中做了什么操作呢?我们暂且放下,等后面的时候再探究。
既然又回到了_objc_rootAllocWithZone
,我们重复之前的步骤,进入到_objc_rootAllocWithZone
方法里继续定位,我们很快就看到了如图3所示的内容,又定位了两个底层方法名
我们在找到方法的过程中可以去objc4-781源码里去比对,最终就能定位到我们需要探究的位置。当然第一种定位方式会显得比较笨拙。
2.通过打符号断点来快速定位:
第一步仍然是在例子图
那打个断点,因为调用alloc方法的地方很多,我们首先要知道此时已经到了我们创建的Person
对象的alloc
方法,这时再去探究才更有针对性。
打开设置断点的位置,选择symbolic breakpoint
,设置symbol
为我们需要定位的alloc
,如图4,图5所示
然后继续运行,看到图6所示,发现alloc方法在动态库libobjc.A.dylib里
我们继续依葫芦画瓢设置符号断点为
_objc_rootAlloc
,继续运行又找到了_objc_rootAllocWithZone
方法,继续设置符号断点为_objc_rootAllocWithZone
,然后就找到前面图3所示的方法。
3.通过汇编的方式:
首先仍然是在例子图
那加断点。定位到Person
的alloc
方法后打开汇编,如图7所示,xcode 工具栏 选择Debug --> Debug Workflow --> Always Show Disassembly
就会看到定位到了有Person
标识的一行,而在下面就能看到之前两种方法都定位过的objc_alloc
方法,此时通过第二种方式加符号断点继续跟进源码流程即可。