相信没有人会怀疑,Swift 是 iOS 开发将来的主流语言,可是因为 Swift 语言的不断变化以及庞大的迁移成本,真正把项目迁移到 Swift 语言的公司并很少。而猿题库 iOS 客户端是一个超过 3 年的项目,积累了超过 15 万行的 Objective-C 代码,我相信它在迁移过程当中的经验对不少人有所帮助。程序员
蓝晨钰(@晨钰Lancy)是猿题库 iOS 客户端的负责人,他主导了猿题库 iOS 客户端从 Objective-C 到 Swift 的迁移工做。同时他在实践 Swift 的过程当中,总结了很多心得,此次他将会在 GMTC 大会上分享这方面的话题,如下是我对他的采访,但愿对你们有帮助。编程
问题:向读者简单介绍一下本身吧。安全
我叫蓝晨钰,iOS 开发者,11 年开始接触 iOS 开发,13 年加入猿题库负责 iOS 客户端开发工做,和猿题库一块儿经历了从无到拥有数千万用户的成长,和个人团队一块儿完成了数十个版本的迭代。架构
我从 14 年末 Apple 发布 Swift 语言开始一直关注和学习其知识理念,并在 15 年初在公司推广和实践 Swift 项目,至今在生产环境实践 Swift 已经超过一年,算是有比较丰富的移动客户端开发经验和 Swift 编程经验吧。我的对 Swift 语言的持乐观态度,在公司内积极推动 Swift 语言的实践,也很是享受 Swift 的编程体验。函数
问题:据说你此次打算在 GMTC 上分享的话题是:《当泛型赶上协议 —— Generic Programming with Protcol in Swift》,能简单介绍一下为何选这个主题吗?工具
泛型编程和面向协议编程都是 Objective-C 语言所没有的特性,做为一个老 iOS 开发者来讲,当我第一次接触它们时,个人心里是激动的,我火烧眉毛的想知道,这些个新特性新技术,会给咱们的程序和开发带来怎么样的变化。而通过咱们团队的不断学习和实践,咱们也的确在这当中找到了不少乐趣,积累了很多经验,我但愿能经过此次分享讲它们分享给更多人。学习
问题:你怎么看待泛型编程和面向协议编程在客户端编程的将来?测试
泛型编程是许多现代语言全部的特性,在其余语言的实践经验告诉咱们,泛型是一个强大的工具,常常能有效的提升编程效率和提升代码的复用程度。面向协议编程则是由 Swift 提出的编程范式,强大的表达力和抽象能力,毫无疑问会变成一项重要工具。而这二者的结合则是一种全新的体验,这也是我此次分享的一个重要部分。spa
同时,因为 Swift 语言缺少相似 objc runtime 的机制,我认为泛型编程和面向协议编程做为实现以前 runtime 所实现功能的替代,将愈来愈成为 iOS 开发者须要掌握的重要技能。设计
问题:猿题库当前对 Swift 的使用到什么程度?已经彻底迁移到 Swift 了吗?
猿题库有两个客户端项目,分别是老师端和学生端,他们都是 Swift 和 Objective-C 混编的项目,并无彻底迁移到 Swift。其中猿题库老师端是在 Swift 发布以后不久启动的项目,咱们在这个项目中开始推行 Swift 语言,因此这个项目是一个 Swift 语言为主的项目,Objective-C 部分主要为复用旧代码。
而猿题库学生端是咱们的主项目,这个项目从 iOS 5 时代开始,一直使用 Objective-C 编写,直到近期 Swift 升到 2.x 以后,咱们认为 Swift 已经足够成熟,而且咱们在老师端中积累了足够的经验后才开始向 Swift 迁移的。目前学生端的项目中,大部分仍是 Objective-C 语言实现,但新实现的页面和功能基本都使用 Swift 语言来编写。
问题:你认为猿题库大概还须要多长时间可以彻底迁移到 Swift?
事实上,在生产环境中,几乎没有人愿意在收益甚微的状况下把 Objective-C 代码重写一次,由于重写意味着大量的研发资源和测试资源的消耗,而这基本不会产生实际意义上的产品收益。另外 Apple 在 Swift 和 Objective-C 的桥接上作了至关多的努力,大部分状况下,咱们均可以不太费力的在 Swift 中复用 Objective-C 代码。
因此大部分公司的策略都会是新功能用 Swift 语言实现,旧功能先维持现状,等到产品变更或是架构变更的时候再使用 Swift 语言实现,这也是猿题库所采用的策略。因此我想短期内不太可能彻底迁移到 Swift 吧。若是非要说一个时间的话,我推测大约一年以后大部分业务应该会迁移到 Swift,而整个项目完全迁移恐怕就须要两到三年以上了。
问题:你认为 Swift 何时可以达到 ABI 稳定?
老实说,我也不知道。Swift 的发展很快,我此次主题要讲的泛型相关的实践,在 Swift 1.x 的时候就无法实现。Swift 项目组的 Chris Lattner 也公开表示 Swfit 3.0 不会达到 ABI 稳定而且会缺乏一些重要的泛型功能。咱们只能期待在 Swift 3.x 或 Swift 4 的时候会有惊喜吧。
问题:对比 Swift 和 Objective-C,你以为 Swift 最大的优点是什么?
Swift 的优点有不少,我比较喜欢的有几点:更安全的类型,表明更少的 Bug 和更低的崩溃率;更简洁的语法,表明更少的代码和更快的编程速度;强大的函数式、泛型、协议等特性,表明更能发挥程序员的想象力。选一个的话,我选最后一个,强大的特性给了我很大的编程愉悦感。
问题:对于从 Objective-C 迁移到 Swift,你有遇到什么值得分享的坑吗?
从 Objective-C 迁移到 Swift 表明着在很长一段时间内都是处于混编的状态,这里我认为最重要的经验是必定要有一个迁移的规范和指南来约束开发团队哪些部分须要迁移 Swift 而哪些部分不要,接口应该如何设计才能兼顾混编调用。举个例子,因为 Swift 调用 Objective-C 是方便的可靠的,反之则有许多的限制,因此设计接口的时候,须要考虑这个模块会不会被 Objective-C 调用,若是是的话,应该避免使用 Swift 语言的特性,又或是制定一套规则,来 Swift 语言的接口如何转成 Objective-C 兼容的接口。
问题:对于学习 Swift,你有什么推荐的方法或资料吗?
iBooks 上有 Apple 推出的 Swift Programming 系列书籍是全部 iOS 开发者的必读和参考书目。iTunes U 上有 Stanford 的 Developing iOS Apps with Swift,讲师是 Apple 工程师 Paul Hegarty,推荐新入门的 iOS 开发者学习。
Objc.io 上的 Advanced Swift 是我最近在读的书,内容绝对对得起 Advanced 这个词,推荐有必定基础 Swift 开发者阅读。此外 Github 上有大量的 Swift 开源项目,能够阅读源码来学习。
最后,也是最重要的,多写,多想,实践是最好的学习方式。
问题:你对今年 WWDC 有什么期待吗?
最大的指望是能去一次 WWDC(笑),惋惜咱们公司每一年到 6 月高考的时候就是最忙的时候,因此这个愿望只能等之后了。对 WWDC 自己的话,指望 Apple 能弄出一些新东西,好比我很看好的虚拟现实相关的产品和技术。
另外但愿 Apple 能加快 Swift 的推动,好比发布与 Google 合做推动 Swift 语言在 Android 客户端的应用之类。