iOS底层原理03:NSObject的alloc 源码分析

2021-03-20  本文已影响0人  黑白森林无间道

本文主要探索NSObject中的alloc是与自定义类的alloc源码流程的区别,以及为什么NSObject中的alloc不走源码工程。

NSObject的alloc无法进入源码的问题

image image image

探索过程

【第一步】探索[NSObject alloc]走的是哪步源码

接下来,我们就来探索为什么NSObject的alloc会出现这种情况,首先,

image image

【第二步】探索 NSObject 为什么走 objc_alloc?

首先,我们来看看 NSObjectHTPerson的区别

然后根据第一步中汇编的显示,可以看出,NSObjectHTPerson 都调用了objc_alloc,所以这里就有两个疑问

HTPerson中callAlloc走两次的原因

image image

以下是第二次走到callAlloc方法中的调用堆栈情况

image

所以由上述调试过程可以得出,HTPerson两次callAlloc的原因是首先需要去查找sel,以及对应的imp的关系,当前需要查找的是 alloc 的方法编号,但是为什么会找到objc_alloc?这个就需要问系统了,肯定是系统在底层做了一些操作。请接着往下看

NSObject中alloc走到objc_alloc的原因

这部分需要通过 LLVM源码(即llvm-project)来分析
准备工作:首先需要一份llvm源码

image image image image image image

由此可以得出 NSObject中的alloc 会走到 objc_alloc,其实这部分是由系统级别的消息处理逻辑,所以NSObject的初始化是由系统完成的,因此也不会走到alloc的源码工程中

上一篇下一篇

猜你喜欢

热点阅读