[iOS-Release] Xcode 构建部署时的相关概念

Xcode Concepts

Target

一个Target代表了一个可构建出的产品,还包括构建产品时的指令集。构建的过程就是根据指令集的设置将Project或Workspace中的指定文件转化成对应的产品。一个Project可以包含多个Target,每一个Target对应了唯一的产品。构建产品时的指令集可以在Xcode中的Build Settings和Build Phases中设置。Target默认继承自Project中的Build Settings,但是可以针对每一个Target设置其自己的Build Settings,最终构建时以Target级别的设置为准。最多同时只能有一个活跃的Target(active target),即构建时使用的 Target,通过Scheme指定活跃的Target。
一个Target可能依赖于其他的Target,如果两个Target在同一个Workspace下,Xcode可以发现这个隐含的依赖关系,并根据依赖关系按顺序构建。当然也可以在Build Settings中设置明确的依赖关系。

Project

Project Editor Help

一个Project中可以包含多个Target,Project相当于一个仓库包含了所有用于构建Target对应产品的元素,包括源文件,多媒体资源,构建信息等。Project定义了默认的Build Settings供所有的Target继承。一个Project文件包含的内容包括以下几部分:

  • 源文件的引用,包括代码文件,资源文件,图片文件,nib文件(.xib,.storyboard),Libraries和Frameworks。
  • 分组(Group),用于以更好的结构组织源代码。
  • 构建配置(build configuration),一个Project中可以设置多套构建配置,之后在不管是Project级别还是Target级别的Build Settings中,每一个选项都可以针对不同的构建配置设值。也就是说,一个构建配置就代表了一套Build Settings中的选项组合,Target可以根据情况选择不同构建配置去构建产品。
  • Target,如上所述。
  • 可执行环境(executable environment),用于调试和测试程序,比如设置命令参数,环境变量等,可在scheme中的Run和Test中设置。

Build Settings

Build Settings指的是一个产品的构建过程中在各方面的应如何执行的信息。Build Settings可以分为Project级别和Target级别,Target级别默认继承自Project级别,然后可以重新修改,最终以Target级别的设置来执行构建过程。不管是哪一个级别,Build Settings中的选项还可以根据不同的构建配置设置不同的值,最终Target根据某一套构建配置中的Build Settings值去构建产品。在Target级别除了有对应Project级别的Build Settings以外,还有Build Phases用于管理构建时的源文件,资源文件,依赖库等。

Workspace

Workspace可以包含一组Project和相关的文档,使它们在一起协同工作。Workspace扩展了Xcode的工作流范围,在Workspace中,即使是不同的Project间也可以无缝的索引文件。当构建时,一个Target可以依赖其他同一个Workspace下的Project中的Target,Xcode可以发现这个隐含的依赖关系,并根据依赖关系按顺序构建。当然也可以在Build Settings中设置明确的依赖关系。默认情况下,Workspace中的所有Project会构建到同一目录中,因此,构建后的文件是对所有Project可见的,如果多个Project引用了相同的库,则不需要copy到每一个Project中。一个Project可以被包含进多个不同的Workspace中,同时也可以单独通过Project来工作和构建,Project有自己的构建目录,但会被Workspace覆盖。

Scheme

Scheme Editor Help

Scheme是一套构建方案,包括了一个项目中的某个Target,和这个Target构建时使用的构建配置。可以创建多个Scheme,但同时只能有一个Scheme是活跃的。可以在Manage Schemes中设置一个Scheme的Container,如果设置为Project则在其他Workspace中该Scheme也可用,如果设置为Workspace,则Scheme只在该Workspace中可用。当选择了一个活跃的Scheme后,其下一级即选择目标设备。

如果在 Scheme 管理面板中勾选了一个 Scheme 的 Shared 选项,那么该 Scheme 对应的 .xcscheme 文件将被存放到 ProjectName.xcodeproj/xcshareddata/xcschemes路径下,供团队成员间通过 Git 共享。而一个没有选择 Shared 选项的 Scheme 则存放在ProjectName.xcodeproj/xcuserdata的对应路径下。

你可能感兴趣的:([iOS-Release] Xcode 构建部署时的相关概念)