前言

在 iOS 开发过程中,我们经常会在 Xcode 里面做一些配置,比如添加系统库、第三方库,修改证书配置文件,修改编译属性等等。

在这个过程里面,一般大家仅仅只是根据经验来配置这些,并没有比较清晰的认识 Xcode Project 的层次结构。最近由于接触这个比较多,做了一些如下总结。

一、Xcode Project 概念Project

Xcode 中的 project 里面包含了所有的源文件、资源文件和构建一个或者多个 product 的信息。project 利用他们去编译我们所需的 product,也帮我们组织它们之间的关系。一个 project 可以包含一个或者多个 target。project 定义了一些基本的编译设置,每个 target 都继承了 project 的默认设置,每个 target 可以通过重新设置 target 的编译选项来定义自己的特殊编译选项。

一个 Xcode project 文件包含以下这些信息:

  • 源文件引用

    • 源代码,包含头文件和实现文件
    • 内部和外部的静态库和动态库
    • 资源文件
    • 图片文件
    • 界面构建文件(nib)
  • 在文件结构的导航中,使用 Groups 去组织源文件
  • 工程层级编译配置。可以给工程指定超过一个编译配置,比如:编译配置的 release 和 debug。

Target

target 定义了构造一个 product 所需的文件和编译指令。一个 target 对应于一个 product。target 就是 
告诉编译系统要编译的文件和编译设置。编译指令就是根据 build settings and build phases 来确定的。

二、图解 project.pbxproj 文件

project.pbxproj 文件是 ProjectName.xcodeproj 包里面的一个配置文件,我们修改 Project 和 target 里面的配置,实际上就是修改了 project.pbxproj。

一个 Xcode 的 project.pbxproj 文件是由一个 24 位的 UUID 标识的对象值。

project.pbxproj 里面的每一种元素类型都是由 isa 来标识的。

project.pbxproj 文件结构

[Objective-C] 查看源文件 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
// !$*UTF8*$!
 
    {
        archiveVersion = 1;
        classes = {
        };
        objectVersion = 45;
        objects = {
        ...
        };
        rootObject = 0867D690FE84028FC02AAC07 /* Project object */;
    }

1、XCConfigurationList

编译配置列表

示例:

[Objective-C] 查看源文件 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
DE218BE11BDB7AA7003717DF /* Build configuration list for PBXProject "ShareSDKDemo" */ = {
      isa = XCConfigurationList;
      buildConfigurations = (
          DE218C111BDB7AA7003717DF /* Debug */,
          DE218C121BDB7AA7003717DF /* Release */,
      );
      defaultConfigurationIsVisible = 0;
      defaultConfigurationName = Release;
  };
  DE218C131BDB7AA7003717DF /* Build configuration list for PBXNativeTarget "ShareSDKDemo" */ = {
      isa = XCConfigurationList;
      buildConfigurations = (
          DE218C141BDB7AA7003717DF /* Debug */,
          DE218C151BDB7AA7003717DF /* Release */,
      );
      defaultConfigurationIsVisible = 0;
      defaultConfigurationName = Release;
  };

XCBuildConfiguration

XCBuildConfiguration 元素定义了编译的配置

示例:

[Objective-C] 查看源文件 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
870C88151338ABB600A69309 /* Debug */ = {
    isa = XCBuildConfiguration;
    buildSettings = {
            .....
            PRODUCT_NAME = "$(TARGET_NAME)";
    };
    name = Debug;
};
870C88161338ABB600A69309 /* Release */ = {
    isa = XCBuildConfiguration;
    buildSettings = {
            .....
            PRODUCT_NAME = "$(TARGET_NAME)";
    };
    name = Release;
};

2、PBXGroup

PBXGroup 这个元素下面包含了Xcode 工程的文件目录。在Xcode 文件体系里面,是使用 Group 组织管理的。

示例:

[Objective-C] 查看源文件 复制代码
1
2
3
4
5
6
7
8
9
DE218BDD1BDB7AA7003717DF = {
    isa = PBXGroup;
    children = (
        DE218C251BDB8836003717DF /* ShareSDK */,
        DE218BE81BDB7AA7003717DF /* ShareSDKDemo */,
        DE218BE71BDB7AA7003717DF /* Products */,
    );
    sourceTree = "<group>";
};

3、PBXNativeTarget

示例:

[Objective-C] 查看源文件 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
DE218BE51BDB7AA7003717DF /* ShareSDKDemo */ = {
    isa = PBXNativeTarget;
    buildConfigurationList = DE218C131BDB7AA7003717DF /* Build configuration list for PBXNativeTarget "ShareSDKDemo" */;
    buildPhases = (
        DE218BE21BDB7AA7003717DF /* Sources */,
        DE218BE31BDB7AA7003717DF /* Frameworks */,
        DE218BE41BDB7AA7003717DF /* Resources */,
    );
    buildRules = (
    );
    dependencies = (
    );
    name = ShareSDKDemo;
    productName = ShareSDKDemo;
    productReference = DE218BE61BDB7AA7003717DF /* ShareSDKDemo.app */;
    productType = "com.apple.product-type.application";
};

PBXSourcesBuildPhase

示例:

[Objective-C] 查看源文件 复制代码
1
2
3
4
5
6
7
8
4DF8B22D1171CFBF0081C1DD /* Sources */ = {
        isa = PBXSourcesBuildPhase;
        buildActionMask = 2147483647;
        files = (
                4DF8B23E1171D0310081C1DD /* test.mm in Sources */,
        );
        runOnlyForDeploymentPostprocessing = 0;
};

PBXFrameworksBuildPhase

示例:

[Objective-C] 查看源文件 复制代码
1
2
3
4
5
6
7
4D05CA2C119304BD00125045 /* Frameworks */ = {
    isa = PBXFrameworksBuildPhase;
    buildActionMask = 2147483647;
    files = (
    );
    runOnlyForDeploymentPostprocessing = 0;
};

PBXResourcesBuildPhase

示例:

[Objective-C] 查看源文件 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
8D1107290486CEB800E47090 /* Resources */ = {
        isa = PBXResourcesBuildPhase;
        buildActionMask = 2147483647;
        files = (
                535C1E1B10AB6B6300F50231 /* ReadMe.txt in Resources */,
                533B968312721D05005E617D /* Credits.rtf in Resources */,
                533B968412721D05005E617D /* InfoPlist.strings in Resources */,
                533B968512721D05005E617D /* MainMenu.nib in Resources */,
                533B968612721D05005E617D /* TableEdit.nib in Resources */,
                533B968712721D05005E617D /* TestWindow.nib in Resources */,
        );
        runOnlyForDeploymentPostprocessing = 0;
};

PBXShellScriptBuildPhase

示例:

[Objective-C] 查看源文件 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
4D22DBAE11674009007AF714 /* ShellScript */ = {
        isa = PBXShellScriptBuildPhase;
        buildActionMask = 2147483647;
        files = (
        );
        inputPaths = (
        );
        outputPaths = (
        );
        runOnlyForDeploymentPostprocessing = 0;
        shellPath = /bin/sh;
        shellScript = "./fix_references.sh";
};

PBXHeadersBuildPhase

示例:

[Objective-C] 查看源文件 复制代码
1
2
3
4
5
6
7
87293EBC1153C114007AFD45 /* Headers */ = {
    isa = PBXHeadersBuildPhase;
    buildActionMask = 2147483647;
    files = (
    );
    runOnlyForDeploymentPostprocessing = 0;
};

参考文献

1、Xcode 中的 workspace, project, target, scheme 译文 官文

2、Xcode Project File Format link

3、pbxplorer link

 

Xcodeproject详解的更多相关文章

  1. Xcode - Xcodeproject详解

    前言 在 iOS 开发过程中,我们经常会在 Xcode 里面做一些配置,比如添加系统库.第三方库,修改证书配置文件,修改编译属性等等. 在这个过程里面,一般大家仅仅只是根据经验来配置这些,并没有比较清 ...

  2. Linq之旅:Linq入门详解(Linq to Objects)

    示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...

  3. 架构设计:远程调用服务架构设计及zookeeper技术详解(下篇)

    一.下篇开头的废话 终于开写下篇了,这也是我写远程调用框架的第三篇文章,前两篇都被博客园作为[编辑推荐]的文章,很兴奋哦,嘿嘿~~~~,本人是个很臭美的人,一定得要截图为证: 今天是2014年的第一天 ...

  4. EntityFramework Core 1.1 Add、Attach、Update、Remove方法如何高效使用详解

    前言 我比较喜欢安静,大概和我喜欢研究和琢磨技术原因相关吧,刚好到了元旦节,这几天可以好好学习下EF Core,同时在项目当中用到EF Core,借此机会给予比较深入的理解,这里我们只讲解和EF 6. ...

  5. Java 字符串格式化详解

    Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...

  6. Android Notification 详解(一)——基本操作

    Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...

  7. Android Notification 详解——基本操作

    Android Notification 详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 前几天项目中有用到 Android 通知相关的内容,索性把 Android Notificatio ...

  8. Git初探--笔记整理和Git命令详解

    几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...

  9. Drawable实战解析:Android XML shape 标签使用详解(apk瘦身,减少内存好帮手)

    Android XML shape 标签使用详解   一个android开发者肯定懂得使用 xml 定义一个 Drawable,比如定义一个 rect 或者 circle 作为一个 View 的背景. ...

随机推荐

  1. 解决Button设置disabled后无法执行后台代码问题

    一.开始调式下面的程序,发现Button在js中设置disabled后无法执行后台代码(btnsave_Click)问题 <asp:Button ID="btnsave" r ...

  2. python __name__

    当你打开一个.py文件时,经常会在代码的最下面看到if __name__ == '__main__':,现在就来介 绍一下它的作用. 模块是对象,并且所有的模块都有一个内置属性 __name__.一个 ...

  3. 几个简单实用的css效果

    1.要使按钮具有3D效果,只要将它的左上部分边框设置为浅色,右下部分边框设置为深色即可. eg:#button { background: #888; border: 2px solid; borde ...

  4. 关于JavaScript的浅拷贝和深拷贝

    在 JS 中有一些基本类型像是Number.String.Boolean,而对象就是像这样的东西{ name: 'Larry', skill: 'Node.js' },对象跟基本类型最大的不同就在于他 ...

  5. C++笔试题(转)

    http://blog.csdn.net/hxz_qlh/article/details/16864567 这里面列举的题考察的东西都非常细,包括strcpy,字符串,大.小端的判断,很容易犯错,值得 ...

  6. 关于vco

    关于vco:vco是vSphere 4开始,在vCenter中默认附件安装的一个新组件.它的作用主要是提供工作流管理.这么说可能有些抽象,让人搞不明白vco到底是做什么用的.其实很简单,以前的vCen ...

  7. 34 网络相关函数(二)——live555源码阅读(四)网络

    34 网络相关函数(二)——live555源码阅读(四)网络 34 网络相关函数(二)——live555源码阅读(四)网络 2)socketErr 套接口错误 3)groupsockPriv函数 4) ...

  8. Quartz表达式详解(转载)

    1.   CronTrigger时间格式配置说明 CronTrigger配置格式: 格式: [秒] [分] [小时] [日] [月] [周] [年] 序号 说明 是否必填 允许填写的值 允许的通配符 ...

  9. Graph Valid Tree

    Given n nodes labeled from 0 to n - 1 and a list of undirected edges (each edge is a pair of nodes), ...

  10. java入门 第一季4

    1.数组 1).声明数组 数据类型[]数组名; 数据类型 数组名[]; 2).分配空间 数组名=new 数据类型[数组长度]: 3).赋值 score[0]=98: 直接创建一个长度为4的数组 int ...