在项目中经常使用的
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,选择对应的版本的即可。