手撕iOS底层 01 -- 源码探索的方式

在项目中经常使用的alloc方法, 如果想要探索这个方法的底层实现, 该如何下手呢?

所以本篇文章主要记录探索底层源码的三种方式, 起到抛砖引玉的作用。

  • 源码探索的三种方式:
    • 符号断点
    • control + step into
    • 汇编

0x00 符号断点

01.jpg

让程序跑起来,来到断点处。

02.jpg

新建一个Symbolic Breakpoint...

03.jpg

创建一个alloc的符号断点。

04.jpg

接着点击Continue program execution

05.jpg

然后就跳到这里了,开头写着libobjc.A.dylib这个动态库。


0x01 Control + Step into

从新运行,还是来到断点处。

不按Control显示的样式

看调试工具状态栏,这个是不按control的状态显示,

按Control显示的样式

按住Control键, 图标就会不一样。然后一直点、 点、 进去。

08.jpg

然后就看到objc_alloc,然后去打一个objc_alloc的符号断点,就可以看到当前所在的库是libobjc.A.dylib


0x02 汇编

同样还是运行到断点处

09.jpg

选择Xcode的菜单Debug--->Debug Workflow--->Always Show Disassembly

10.jpg

进到汇编里来,在objc_alloc这里打个断点,继续运行到这个断点,按Control键进到里面来

11.jpg

也可以看到objc_alloc,然后在符号断点打一个断点,和探索方式2类似。 也可以找到我们想要看到的东西。


总结

从以上的各种方式探索得知,想要探索的东西在libobjc.A.dylib

然后在苹果的开源网站去找这个库,有没有开源。

苹果开源库所有这里可以选择,比如选择macOS---> 10.15.1搜索objc,选择对应的版本。

苹果开源库分门别类 这里比较容易找一些。搜索ojbc,选择对应的版本的即可。

你可能感兴趣的:(手撕iOS底层 01 -- 源码探索的方式)