Xcode Project是一个包含构建一个或多个软件产品所需要的一切文件、资源及信息的仓库。 Project包含构建产品的所有元素,并负责维护各个元素之间的关系。它包含一个或多个target,这些target指定如何构建产品。Project 为其中的target定义了默认的编译设置(每个target也可以覆盖默认的设置,指定自己的构建设置)。
Xcode Project 文件包含下面的一些信息:
对源文件的引用:
源代码,包括头文件和实现文件
库和框架,内部和外部的
资源文件
图像文件
Interface Builder(NIB)文件
Groups 导航栏中用于组织文件资源
Project级别的构建设置。你可以为一个项目指定多个构建设置;例如,你有debug和release的生成设置。
Targets,每个Target可定制的内容:
Project 构建的一个Product的引用
构建某个产品所用的全部文件的引用
构建某个产品所用的构建设置,包括对其他target或其他设置的依赖关系;如果对应的target没有覆盖原来的Project的设置,则使用原来Project的。
可用来调试或测试程序的执行环境,每个执行环境可定制的内容:
当用Xcode运行或调试可执行文件的时候,加载什么东西
传递给可执行文件的命令行参数
程序运行时候的环境变量。
一个Project可以单独存在或包含在一个工作空间中。
Xcode Target
一个Target指定一个产品来构建并且包含了从项目或workspace的全部(或部分)文件中构建产品的指令。一个target定义了一个单一的产品。它来组织构建产品的输入文件(包含构建产品必需的所有文件:源文件,预编译这些源文件的指令)。Project 可以包含一个或多个target,每个target产生一个产品,可对应一个不同的应用。
构建产品的指令有两种形式:构建设置和构建阶段(Build settings 和 Build phases), 你可以在Xcode的项目editor中检查并编辑它们。target继承了project的构建设置。但是你可以在target层次覆盖任何project的设置。在同一时刻,只有一个target是活跃的。Xcode scheme指定了那个target是活跃的。
一个target以及由它生成的产品可以与其他的target建立关系。如果构建一个target需要另一个target的输出,我们就说第一个target依赖于第二个target。如果它们两个都在同一个workspace中,xcode可以发现这种依赖关系,那么它就会按照需要的顺序来构建产品。这种关系叫做隐式依赖。你也可以在你的构建设置中设置显式依赖,并且你可以指定某两个xcode可能判定为有隐式依赖的target之间没有依赖关系。例如:你可以构建一个库以及一个链接这个库的在同一个workspace下的应用程序。xcode可以发现这种关系并且自动先构建这个库。当然,如果你确实需要链接到一个与当前workspace下不同版本的库中,你可以在你的构建设置中创建一个显示依赖,这将覆盖原来的隐式依赖。
Xcode Scheme
Xcode scheme 定义了可构建的target的集合、构建时可用的设置以及可执行的测试的集合。
你可以创建任意数目的scheme,但是同一时刻只有一个是活跃的。你可以指定某一个scheme应该是存储在project中还是workspace中——如果是存储在project中,它在所有包含这个project的workspace中都是可用的,若是存储在workspace中,它只能在当前的workspace中可用。当你选择一个活跃的scheme,你也就同时选择了一个运行目的(也就是说,这个产品将要构建在那个硬件结构中)。
Xcode Workspace
Workspace是一个xcode文档,它将一些项目以及其他的文档组织在一起,以便于你基于它们进行工作。一个Workspace可以包含任意个xcode项目,你也可以往里面加一些你想要的文件。 另外,为了阻止每个项目中的文件,workspace 为包含的项目以及它们的target提供了显式或隐式的关系。
阅读拓展:
解密 Build
应用配置和项目结构
project、target的build settings、info信息剖析