猿题库从 Objective-C 到 Swift 的迁移

引言 相信没有人会怀疑,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 提出的编程范式,强大的表达力和抽象能力,毫无疑问会变成一项重要工具


而这两者的结合则是一种全新的体验,这也是我这次分享的一个重要部分


同时,由于 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 客户端的应用之类


写在最后 由 InfoQ 主办的 GMTC 全球移动技术大会将于6月24日在北京召开


来自 BAT、携程、滴滴和社区的技术专家联袂分享,主题包括应用架构、性能优化、动态化、插件化、Swift、React Native、Weex等


本周移动大会 8 折最后一周,我的粉丝本周前 20 人报名享受 6 折 1080 的优惠呦,手慢无!手慢无! 优惠码: GMTC-TangQiao



发表回复