手写一个PrattParser基本运算解析器4: 简述iOS的编译过程

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第1张图片

点击查看 基于Swift的PrattParser项目


iOS项目的编译过程与PrattParser解析器

前面三篇我们看到了PrattParser解析器的工作原理, 工作过程, 我们了解到PrattParser解析器实际上是模拟了编译过程中的 词法分析语法分析语义分析中间代码生成 这几个编译前端过程.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第2张图片

那么PrattParser解析器与我们实际开发iOS项目有什么样的联系呢? 其实, 编译前端的工作只是iOS编译过程中的一小部分工作. 对此, 这就不得不说一下iOS项目的编译过程了.

首先, 我们先说结论, 对于一个Objective - C 项目来说, LLVM 中的 Clang 作为编译器, 负责代码编译的主要过程.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第3张图片

但是对于一个Swift项目, 编译前端的工作则是由 Swift 自己编写的编译器完成, 中间代码优化编译后端的工作仍然是 LLVM 中的 Clang 来完成的.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第4张图片

接下来, 我们就结合着实际 OC 项目 和 Swift 项目 的编译过程来具体说说iOS的编译过程.


OC项目的编译过程

对于一个 OC项目 的项目编译过程来说, 就是从你点击运行 Run 或者 Build 开始的.

那么我们怎么看一下一个iOS项目中编译过程都做了哪些事情呢? 我们如图所示需要点击xcode开发工具的 Show the Report navigator, 则可以查看我们所有的运行, 编译, 单元测试记录.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第5张图片

选择一次编译记录, 我们发现具体的编译过程是如下图所示的.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第6张图片

上图主要分为三个编译过程.

  • Prepare build : 准备阶段, 主要是创建一些编译过程的文件夹, 以及创建编译描述.

    手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第7张图片

  • Build target Pods-xxx : 编译项目依赖cocoapods的相关三方库, 并且制作对应的静态库文件. 这里就不过多叙述了.

    手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第8张图片

  • Build target OCBuild : 编译项目阶段, 编译过程如下所示.

    手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第9张图片

    上图的蓝色区域内部就是执行了 LLVM 相关的 编译前端, 编译后端 的相关工作. 也就是说 PrattParser解析器实际上只是模拟了其中编译前端的工作. 虽然占据的步骤很少, 但是却是整个App编译过程中最重要的一部分.

    另外由于App编译步骤的改动, 最新的这一版的App编译顺序已经是和以前App编译步骤顺序都不同了, 但是在本质上它们的工作内容大体上是一致的.


Swift项目的编译过程

Swift项目 的编译过程实际上在外部看起来和 OC项目 的过程基本上是一致的. 这里就不过多叙述了.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第10张图片

对于 asset资源编译过程 LaunchScreen Main编译过程 app签名过程 app合法性验证过程 app打包过程 这样的一些过程, 我们只需要了解即可. 我们要深究的是 在编译源码的过程中, OC项目Swift项目 都有哪些不同之处?


OC 与 Swift 编译代码过程

前面我们说过对于一个Objective - C 项目来说, LLVM 中的 Clang 作为编译器, 负责代码编译的主要过程. 但是对于一个Swift项目, 编译前端的工作则是由 Swift 自己编写的编译器完成, 中间代码优化编译后端的工作仍然是 LLVM 中的 Clang 来完成的.

在编译OC源代码的过程具体的主要是这样的. 整个过程全部由 LLVM 来构建. 生成的中间代码为 LLVM IR 的形式的.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第11张图片

对于Swift编译过程来说, 和编译OC源代码还是有一定区别的.

由于 Swift编译器 作为整个链路的编译前端, 同时我们根据官方的Swift编译器架构说明, Swift编译器并不是直接生成 LLVM IR 形式的中间代码, 而是生成 SIL 格式的中间代码, 经过优化之后, 才会最终生成 LLVM IR 形式的中间代码.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第12张图片

所以对于Swift编译过程来说, 大体的流程图应该是这样的.

手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第13张图片


总结

通过这样的对比, 我们就对iOS编译过程以及PrattParser 在iOS编译过程中到底是模拟了哪个过程有了大体的了解.

同时, PrattParser解析器 这一个系列就算小完结了, 如果有问题, 欢迎评论指导, 骚栋这里感谢了~


点击查看 基于Swift的PrattParser项目


手写一个PrattParser基本运算解析器4: 简述iOS的编译过程_第14张图片

你可能感兴趣的:(编译原理:,ios,编译原理,xcode)