2017GMTC Swift在Airbnb的应用实践

主要分享了Airbnb使用Swift的一些经验,Airbnb的Swift代码的使用已占大约80%~90%,算是业界比较多的了。

Swift的主要特性以及在Airbnb的应⽤

安全
Swift使用Optional Variable区分是否为空,TT?为不同的两个类型,使用WrapUnwrap进行转换

对于let vs var,尽量使用不可变的let

Swift提供了高级枚举类型,使得enum变得异常强大,可以支持之前传统上只有类才可以支持的特性,比如计算属性、实例方法、初始化、扩展、协议等。

Protocol Oriented Programming
这个之前没有注意,但事实上Swift整个语言与OC已经截然不同,OC依然是传统的面向对象编程,而Swift已经是面向协议的编程。

可以通过ASIHttpRequestAFNetworking各自实现网络请求的方式来比较

ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];
[request setDidFinishSelector:@selector(requestDone:)];
[request setDidFailSelector:@selector(requestWrong:)];
[request startAsynchronous];

ASIHttpRequest是面向对象的,你需要实现一个对象的实例,设置属性,调用对应的方法。

AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
[manager GET:@"www.olinone.com" parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) {
    
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    
}];

AFNetworking是面向协议的,你可以看到这里只需要对方法进行直接调用,而不需要了解对象的属性。

我们自己在使用Swift的转换中,似乎还没有意识到这一点。

泛型
在可能处理多种类型的地方使用泛型:


这里类型可能会有如下三种:

CarouselComponent<HomeCardComponent>
CarouselComponent<ExperienceCardComponent>
CarouselComponent<GuidebookComponent>

其他特性
Memory Management:全部是ARC
Less Code:没有.h .m
Faster: Struct 使用栈,Class使用堆;Swift的Copy Write在堆上面
Tuples:支持多元组,不同类型的集合
Access Control:OC的动态特性破坏了访问控制,而Swift不支持动态特性

Airbnb遇到的问题以及解决方案

编译时间

Airbnb在开发的过程中编译的时间越来越长,发现是由于Swift进行“类型推导以及类型检查”时耗费了大量的时间。

如何调试编译时间,发现占时过多的方法:

target -> Build Settings -> Other Swift Flags 添加编译设置
-Xfrontend -debug-time-function-bodies

在“times.txt”文件中查看各个方法的耗时,下面的命令可以排序
xcodebuild -workspace yourWorkspaceName.xcworkspace -scheme schemeName clean build 2>&1 |egrep "d.dms"|sort -nr > times.txt

根据检查出来的问题,总结了一些有针对性的解决方案:

  1. Use CI system to monitor the build time.
  2. Educate engineers to provide type information as much as possible.
  3. Use Lint to prevent engineers from common issues.
  4. Offline type inference (Use SourceKit).

BUCK
使用BUCK编译系统来提高编译速度(并行编译、增量编译、缓存编译中间结果、开源)

Whole Module Optimization

全模块优化WMO的原理就是在编译项目时,将所有源代码合起来作为一个整体进行分析和优化,与单文件优化SFO(Single File Optimization)相区别,通过排除死函数、去inline函数调用等优化最终的目标文件,可以数倍的提高性能。

这篇文章评测 Swift 3.0 项目编译优化选项对编译速度的影响研究了三种模式的编译时间:

  • None: 102s
  • Fast, SFO: 122s
  • Fast, WMO: 89s

这里比较有趣的一点是WMO作为优化了的编译方式,所花的时间比不优化的还要快,官方的解释是既优化了性能,又优化了编译速度(好吧~)

WMO在Release默认打开,但是在Debug默认关闭,这是因为WMO的增量编译做的不好:改动一个文件后,编译器还得把所有的文件再编译一遍。

此外,针对WMO,这篇文章优化 Swift 编译速度有更深入的分析:把所有Model文件全部合并到一个文件去编译,这样做的效率提升超过了WMO。

这是因为,WHO除了合并文件之外,还会在预编译阶段做一些事情,包括:检测并去掉没有被调用的方法和类型;给没有被继承的类或方法加上final标签,优化为静态调用或者内联进去。

这些优化可以大幅提升程序的效率,但是导致在编译阶段每合并一个文件,就会遍历所有文件进行一次检查,使得编译时间过多。 这里采用了一个比较“Tricky”的方法做到只合并文件,不做优化

这种方法解决了上面的问题,不过之前增量编译的问题同样存在:增量编译的颗粒度从File级别增大到Module级别。

Airbnb这里采用的就是这种方法,不过,这种方法对Airbnb很有用,是因为:Airbnb有70个左右的类库,这在某种程度上降低了增量编译的颗粒度级别。但是对于我们这种只有一个Target的工程来说,好处不大。

启动性能

Airbnb通过下面的方法调试启动性能:


动态库合并

Dynamic Library Merging

  • Consolidate Assets (Pre)
  • Build pods filelist
  • Build internal libraries filelist
  • Consolidate Assets (Post)
  • Remove unnecessary embbed libraries

Airbnb通过这些操作,减少了12M的安装控件,以及降低了50%的"Pre-main Time"

Swift和Objective-C混用

提到了两点

  • 一定要在oc代码里面正确的标注nullable
  • 增量编译时间

为了与Swift中可选对象对应,OC提供nullable, nonnull

问题

1 改一个文件,从0开始编译,增量编译有没有影响?更慢?
所有的文件都放到一个里面编译,不加选项的话,就是单个文件。所以增量编译是没有优势的,但是要rebase的话不一样。 Airbnb有七十多个类库,所以可以使用这种方法。

2 设计方法的时候,如何取舍加空或不加空?
不加空最好:避免出错,性能

3 SwiftLint是一个用来规范代码的工具

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,432评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 今天,我和奶奶一起把班里同学买的书一起搬了过来。 我们用小车把书拉到老教学楼里面的楼梯底下,我们把书拿了下来下...
    谷佳琦阅读 758评论 0 2
  • 文/元初 深秋的时节,深秋的年龄,我无可救药的爱上一个姑娘。她是我魂牵梦绕几十年的爱呀,让舟自横的一篇小文,让肖哥...
    元初阅读 425评论 0 1
  • 13年看NBA总决赛第六场我哭了。在热火必输无疑的情况下,雷阿伦投进了一个神奇的三分球。那一刻我看到了奇迹,我感到...
    齐_ab84阅读 106评论 0 0