在项目中经常使用的
alloc
方法, 如果想要探索这个方法的底层实现, 该如何下手呢?所以本篇文章主要记录探索底层源码的三种方式, 起到抛砖引玉的作用。
- 源码探索的三种方式:
符号断点
control + step into
汇编
0x00 符号断点
让程序跑起来,来到断点处。
新建一个Symbolic Breakpoint...
。
创建一个alloc
的符号断点。
接着点击Continue program execution
然后就跳到这里了,开头写着libobjc.A.dylib
这个动态库。
0x01 Control + Step into
从新运行,还是来到断点处。
看调试工具状态栏,这个是不按control的状态显示,
按住Control
键, 图标就会不一样
。然后一直点、 点、 进去。
然后就看到objc_alloc
,然后去打一个objc_alloc
的符号断点,就可以看到当前所在的库是libobjc.A.dylib
。
0x02 汇编
同样还是运行到断点处
选择Xcode
的菜单Debug
--->Debug Workflow
--->Always Show Disassembly
;
进到汇编里来,在objc_alloc
这里打个断点,继续运行到这个断点,按Control
键进到里面来
也可以看到objc_alloc
,然后在符号断点打一个断点,和探索方式2类似。 也可以找到我们想要看到的东西。
总结
从以上的各种方式探索得知,想要探索的东西在libobjc.A.dylib
;
然后在苹果的开源网站去找这个库,有没有开源。
苹果开源库所有这里可以选择,比如选择macOS---> 10.15.1
搜索objc
,选择对应的版本。
苹果开源库分门别类 这里比较容易找一些。搜索ojbc
,选择对应的版本的即可。