iOS alloc到底怎么走

本文将介绍OC对象调用alloc方法在objc源码中是怎么一个流程。

1.首先我们调用 [SLPerson alloc]。

​​​​​​​​​​​​​​

2. SLPerson继承于NSObject,来到alloc方法。

3.接着上一步按理应该调用_objc_rootAlloc,但是打断点却跳到了objc_alloc中,这.....。

为什么会这样呢,这涉及到LLVM底层,alloc一个对象时,ios会先判断这个对象是否被hook(对属性以及方法等进行特殊标注)过,hook完成后,走objc_alloc,调用callAlloc。这也就解释了为什么[NSObject alloc]之后第一步为啥不走_objc_rootAlloc,而是objc_alloc。

4.第一次进callAlloc,会先向SLPerson发送alloc方法,所以到后面会发现整个流程会走两次alloc。

5.由于已经对对象进行过hook操作了,所以这一次[NSobject alloc]终于步入正轨,重见光明,走_objc_rootAlloc了。

6.这次进入callAlloc,走_objc_rootAllocWithZone。

 7._objc_rootAllocWithZone调用_class_createInstanceFromZone

7977行:计算SLPerson类相应内存大小;7984行:在堆开辟了size大的内存;7994绑定了SLPerson类与isa相关联;8022行:返回obj。

综上,得流程图如下:

猜你喜欢

转载自blog.csdn.net/weixin_38016552/article/details/125392271