iOS-底层原理:源码探索的三种方式(一)

(iOS资料大全)

本文主要介绍下源码探索的三种方法

  • 1、符号断点直接跟流程
  • 2、通过按住control+step into
  • 3、汇编跟流程

下面详细讲下这三种方法是如何查找到函数所在的源码库,以alloc为例

1、符号断点直接跟流程

  • 通过下alloc的符号断点

    • 选择断点Symbolic Breakpoint

image

- 符号断点中输入 `alloc`
![image](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/57ee224d77394090a59adad909eac9b3~tplv-k3u1fbpfcp-zoom-1.image)
复制代码
复制代码
  • main中的CJLPerson处 加一个断点

在走到这部分断点之前,需要关闭上面新增的符号断点,原因是因为alloc的调用有很多,如果开启了就不能准确的定位到CJLPersonalloc方法 image 以下为符号断点的关闭状态 image

  • 运行程序, 断在CJLPerson部分

    • 打开 alloc符号断点 ,断点状态为

image

- 继续执行
复制代码
复制代码

image 以下为alloc符号断点断住的堆栈调用情况,从下图可以看出 alloc 的源码位于libobjc.A.dylib库(需要去Apple 相应的开源网址下载 objc源码进行更深入的探索) image

2、通过按住control+step into

  • main中的CJLPerson处 加一个断点,运行程序,会断在CJLPerson位置

image

  • 按住 control键,选择 step into ⬇️键

image

  • 进去后,显示为以下内容

image

  • 再下一个objc_alloc符号断点,符号断点后显示了 objc_alloc所在的源码库

(需要去Apple 相应的开源网址下载 objc源码进行更深入的探索) image

3、汇编跟流程

  • main中的CJLPerson处 加一个断点,运行程序,会断在CJLPerson位置

image

  • xcode 工具栏 选择 Debug –> Debug Workflow –> Always Show Disassembly,这个 选项表示 始终显示反汇编 ,即 通过汇编 跟流程

image

  • 按住control,点击 step into ⬇️键,执行到下图的callq ,对应 objc_alloc

image

  • 按住control,点击 step into ⬇️键进入,看到断点断在objc_alloc部分

image

  • 同样通过objc_alloc的符号断点,得知源码所在库

(需要去Apple 相应的开源网址下载 objc源码进行更深入的探索) image

注意(以下是Apple 提供的源码下载地址): 1、Apple 所有开源源码汇总地址,根据相应的版本查找对应的源码,以mac 10.15为例: macOS --> 10.15 --> 选择10.15 --> 搜索 objc 2、Apple 比较直接的源码下载地址,直接搜索想要下载的源码名称即可,例如objc直接搜索 objc --> objc4/ --> 选择相应的objc的版本

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享