前言

在 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 文件结构

// !$*UTF8*$!

    {
archiveVersion = ;
classes = {
};
objectVersion = ;
objects = {
...
};
rootObject = 0867D690FE84028FC02AAC07 /* Project object */;
}

1、XCConfigurationList

编译配置列表

示例:

 
DE218BE11BDB7AA7003717DF /* Build configuration list for PBXProject "ShareSDKDemo" */ = {
isa = XCConfigurationList;
buildConfigurations = (
DE218C111BDB7AA7003717DF /* Debug */,
DE218C121BDB7AA7003717DF /* Release */,
);
defaultConfigurationIsVisible = ;
defaultConfigurationName = Release;
};
DE218C131BDB7AA7003717DF /* Build configuration list for PBXNativeTarget "ShareSDKDemo" */ = {
isa = XCConfigurationList;
buildConfigurations = (
DE218C141BDB7AA7003717DF /* Debug */,
DE218C151BDB7AA7003717DF /* Release */,
);
defaultConfigurationIsVisible = ;
defaultConfigurationName = Release;
};

XCBuildConfiguration

XCBuildConfiguration 元素定义了编译的配置

示例:

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 组织管理的。

示例:

 
DE218BDD1BDB7AA7003717DF = {
isa = PBXGroup;
children = (
DE218C251BDB8836003717DF /* ShareSDK */,
DE218BE81BDB7AA7003717DF /* ShareSDKDemo */,
DE218BE71BDB7AA7003717DF /* Products */,
);
sourceTree = "<group>";
};

3、PBXNativeTarget

示例:

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

示例:

4DF8B22D1171CFBF0081C1DD /* Sources */ = {
isa = PBXSourcesBuildPhase;
buildActionMask = ;
files = (
4DF8B23E1171D0310081C1DD /* test.mm in Sources */,
);
runOnlyForDeploymentPostprocessing = ;
};

PBXFrameworksBuildPhase

示例:

 
4D05CA2C119304BD00125045 /* Frameworks */ = {
isa = PBXFrameworksBuildPhase;
buildActionMask = ;
files = (
);
runOnlyForDeploymentPostprocessing = ;
};

PBXResourcesBuildPhase

示例:

8D1107290486CEB800E47090 /* Resources */ = {
isa = PBXResourcesBuildPhase;
buildActionMask = ;
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 = ;
};

PBXShellScriptBuildPhase

示例:

 
4D22DBAE11674009007AF714 /* ShellScript */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = ;
files = (
);
inputPaths = (
);
outputPaths = (
);
runOnlyForDeploymentPostprocessing = ;
shellPath = /bin/sh;
shellScript = "./fix_references.sh";
};

PBXHeadersBuildPhase

示例:

 
87293EBC1153C114007AFD45 /* Headers */ = {
isa = PBXHeadersBuildPhase;
buildActionMask = ;
files = (
);
runOnlyForDeploymentPostprocessing = ;
};

参考文献

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

2、Xcode Project File Format link

3、pbxplorer link

 

Xcode - Xcodeproject详解的更多相关文章

  1. 【IOS 开发】Object-C 入门 Xcode 环境详解

    作者 : 韩曙亮 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/38424965 一. Xcode 环境安装 与 工程创建 1. ...

  2. Xcodeproject详解

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

  3. iOS学习——iOS项目Project 和 Targets配置详解

    最近开始学习完整iOS项目的开发流程和思路,在实际的项目开发过程中,我们通常需要对项目代码和资料进行版本控制和管理,一般比较常用的SVN或者Github进行代码版本控制和项目管理.我们iOS项目的开发 ...

  4. [NewLife.XCode]实体类详解

    NewLife.XCode是一个有10多年历史的开源数据中间件,由新生命团队(2002~2019)开发完成并维护至今,以下简称XCode. 整个系列教程会大量结合示例代码和运行日志来进行深入分析,蕴含 ...

  5. iOS开发——高级技术&本地化与国际化详解

    本地化与国际化详解 效果如下:   英语:                                                                    中文: 具体实现如下: ...

  6. Swift语言的基础详解

    1.1.关于swift · Swift 是一种适用于 iOS 和 OS X 应用的全新编程语言,它建立在最好的 C 和 Objective-C 语言之上,并且没有 C 语言的兼容性限制.Swift 采 ...

  7. java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET

    java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET 亲,“社区之星”已经一周岁了!      社区福利快来领取免费参加MDCC大会机会哦    Tag功能介绍—我们 ...

  8. iOS 单元测试之XCTest详解(一)

    iOS 单元测试之XCTest详解(一) http://blog.csdn.net/hello_hwc/article/details/46671053 原创blog,转载请注明出处 blog.csd ...

  9. iOS 视图控制器转场详解

    iOS 视图控制器转场详解 前言的前言 唐巧前辈在微信公众号「iOSDevTips」以及其博客上推送了我的文章后,我的 Github 各项指标有了大幅度的增长,多谢唐巧前辈的推荐.有些人问我相关的问题 ...

随机推荐

  1. windows下nvm安装node之后npm命令找不到问题解决办法

    主要关键解解决办法:===>>适用于所有东西的安装 安装有关环境配置类的软件及其他,一般情况下切记不要安装到c盘programfiles下,否则会出现各种问题的报错!!!切记! nvm安装 ...

  2. VMware12多台虚拟机上网设置

    1.根据镜像安装好linux系统, 2.  把网络适配器移除后,重新添加试试 3. 当按照上述配置后还是无法上网,把VMnet0 桥接模式的自动 ,这里重新点击下自动设置(其实没有做到自动配置) 4. ...

  3. MyBatis踩坑记录

    在线文档: 动态SQL  http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html 1. Error setting null for paramete ...

  4. Android Studio 视图解析

    AS一共同拥有三种视图.我们来分别分析每一种视图的作用. 一.Project视图.(白色字体的文件夹/文件可不关注) 图片中的链接 Gralde介绍:http://stormzhang.com/dev ...

  5. org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'parentId' in 'class java.lang.String'

    Caused by: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named ' ...

  6. 我的notepad++

    我觉得,做开发的一定要有一个简单,但功能强大的文本编辑器.我比较喜欢notepad++,而且一直使用.准备通过这篇文章分享一下我的notepad++配置. 希望广大notepad++用户,如果有好的配 ...

  7. vuejs解析url地址

    函数: // url解析函数 // ?id=111&name=567 => {id:111,name:567} export function urlParse(){ let obj = ...

  8. python读取文件embedded null character是什么原因

    地址的\需要转义符: 将\写成\\ 或者在整个字符串前面添加字母r

  9. sqlite3常用指令

    一.建立数据库 sqlite3.exe test.db 二.双击sqlite-3_6_16目录下的程序sqlite3.exe,即可运行 三.退出 .exit 或者 .quit 四.SQLite支持如下 ...

  10. 如何构建日均千万PV Web站点 (一)

    其实大多数互联网网站起初的网站架构都是(Linux+Apache+MySQL+PHP). 不过随着时代的发展,科技的进步.互联网进入寻常百姓家的生活.所谓的用户的需求,铸就了一个个互联网大牛: htt ...