Build settings探究之—编译优化

前言

xcode中的build settings中有很多涉及到编译设置的选项,了解这些设置,对我们代码的编译速度和安装包大小会有不小的影响,所以我最近对build settings进行了一番探究。

正文

要了解build settings中的各个参数,最好的渠道还是官方文档,于是我们从官方文档中来进行发掘(这里只探讨与编译相关的),我尝试了几乎所有与编译和包大小影响有关的setting,做出了以下总结。

  • Architectures (ARCHS)

Architectures就是指定你的项目所支持的指令集。在build settings中搜索Architectures,相关的有三个,默认情况如下:

image.png

Build Active Architecture Only该编译项用于设置是否只编译当前使用的设备对应的arm指令集。当该选项设置成YES时,你连上一个armv7指令集的设备,就只会生成一个armv7指令集的二进制包。无疑这既可以减小包大小又可以缩减编译时间,所以在debug模式下我们通常设置为YES,而release模式下设置为NO。Valid Architectures表示你项目所支持的指令集合,支持的越多二进制包也就越大,一般为了兼容老设备我们项目使用armv7和arm64。Architectures这里我们设置默认值就好。

  • Optimization
  1. Link-Time Optimization

Link-Time Optimization 是 LLVM 编译器的一个特性,用于在 link 中间代码时,对全局代码进行优化。这个优化是自动完成的,因此不需要修改现有的代码;这个优化也是高效的,因为可以在全局视角下优化代码。更详细的讲解可以阅读这篇文章。总结来说就是,开启LTO后,一方面可以减少汇编代码的体积,另一方面也提高了代码的运行效率。
我在测试中也发现包大小减小了5.7M,首次编译时间会有所提高,但是二次编译反而会有所下降。我这里建议开启Incremental,苹果官方也是建议开启的。

这里在开启Incremental后有可能会出现duplicate symbols for architecture x86_64的错误,这可能是由于你的代码不规范导致的,全局变量在定义时,.h文件中只能声明变量,而不应该定义变量。在.m中定义全局变量的时候也应该增加命名空间或者使用static关键字避免命名冲突。

  1. Optimization Level
    Optimization Level是指编译器的优化层度,优化后的代码效率比较高,但是可读性比较差,且编译时间更长。 它一共有以下几个选项:
  • None: 编译器不会尝试优化代码,当你专注解决逻辑错误、编译速度快时使用此项。
  • Fast: 编译器执行简单的优化来提高代码的性能,同时最大限度的减少编译时间,该选项在编译过程中会使用更多的内存。
  • Faster: 编译器执行所有优化,增加编译时间,提高代码的性能。
  • Fastest: 编译器执行所有优化,改善代码的速度,但会增加代码长度,编译速度慢。
  • Fastest, Smallest: 编译器执行所有优化,不会增加代码的长度,它是执行文件占用更少内存的首选方案

所以说我们平时开发的时候可以选择使用None来不给代码执行优化,这样既可以减少编译时间,又可以看出你代码哪里有性能问题。
而你的release版应该选择Fastest, Smalllest,这样既能执行所有的优化而不增加代码长度,又能使执行文件占用更少的内存。

  1. Optimization (ASSETCATALOG_COMPILER_OPTIMIZATION)

With no value, the compiler uses the default optimization. You can also specify time to optimize for speed of access or space to optimize for a smaller compiled asset catalogs.

官方的介绍说的是当Optimization设为time的时候会使存取的速度最优,而设为space的时候会使编译的包大小最小的优化。然而我这里经过测试发现设置space和time都没有差别,包大小并没有改变。

  • Debug Information Format

这一项设置的是是否将调试信息加入到可执行文件中,改为DWARF后,如果程序崩溃,将无法输出崩溃位置对应的函数堆栈,但由于Debug模式下可以在XCode中查看调试信息,所以改为DWARF影响并不大。所以建议在debug的时候设置为DWARF,而在release的时候设置为DWARF with dSYM file。

  • Deployment Postprocessing和Strip Linked Product

Xcode中Strip Linked Product 的默认设置为YES,但是Deployment Postprocessing的默认设置为NO。Deployment Postprocessing 是Deployment的总开关,所以在打开这个选项之前 Strip Linked Product是不起作用的。打开Deployment Postprocessing后我发现编译速度和包大小都有不少提升。
注意:当Strip Linked Product设为YES的时候,运行app,断点不会中断,在程序中打印[NSThread
callStackSymbols]也无法看到类名和方法名。而在程序崩溃时,函数调用栈中也无法看到类名和方法名。所以一般在release的时候打开就可以了。

更多与symbols有关的settings可以看我mentor的这篇文章Xcode中和symbols有关的几个设置
,讲得非常详细。

其它一些有关的settings:

setting describable
Enable Modules 以语义的形式模块导入系统API,可以有更快的编译速度
Enable Clang Module Debugging 共享debug info以减小包大小和节省编译时间
Dead Code Stripping 消除无效代码
Make Strings Read-Only 复用字符串字面量
Dead Code Stripping 消除无效代码
Build Active Resources Only build的时候只保留相对应的资源文件
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,013评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,205评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,370评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,168评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,153评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,954评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,271评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,916评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,382评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,877评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,989评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,624评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,209评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,199评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,418评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,401评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,700评论 2 345

推荐阅读更多精彩内容

  • 参考文章链接:关于Xcode编译性能优化的研究工作总结 一、编译时长优化Architectures 在Build ...
    夏天的风_song阅读 1,728评论 0 2
  • 1.Xcode IDE概览 说明:从左到右,依次是“导航窗格(Navigator)->边列(Gutter)->焦点...
    小地阅读 5,357评论 0 9
  • 原链接 Additional SDKs 在编译的时候需要附加的SDK。 Architectures 支持的处理器架...
    无名小鱼会吐火阅读 3,282评论 0 6
  • 老师说过,当你想写一个主题,眼睛所及之处,触觉展开之处都是与此相关的。 最近两天触觉都是与孩子有关的,眼睛所及之处...
    VineyZhong阅读 317评论 0 0
  • 一般购买ECS服务器都会有个系统盘,如果系统盘容量不够的话,需要在ECS实例配置数据盘来保存数据,如果已经为 EC...
    曼巴童鞋阅读 4,398评论 0 0