猿题库从 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 客户端的应用之类。

猿题库从 Objective-C 到 Swift 的迁移的更多相关文章

  1. 猿题库 iOS 客户端架构设计

    原文: http://mp.weixin.qq.com/s?__biz=MjM5NTIyNTUyMQ==&mid=444322139&idx=1&sn=c7bef4d439f4 ...

  2. 猿题库 iOS 客户端架构设计-唐巧

    序 猿题库是一个拥有数千万用户的创业公司,从20013年题库项目起步到2015年,团队保持了极高的生产效率,使我们的产品完成了五个大版本和数十个小版本的高速迭代. 在如此快速的开发过程中,如何保证代码 ...

  3. 【android】如何实现猿题库题目的排版

    最近我们的产品来了个新的模块,类似猿题库一样,给学生做题提高成绩的. 要求如下: 1:支持单选.多选.填空题 2:支持图片文字混排 3:输入框有交互,排版精致美观 4:为了体验优化,不能使用网页实现效 ...

  4. 猿题库 iOS 客户端架构设计(原文地址:http://gracelancy.com/blog/2016/01/06/ape-ios-arch-design/)

    猿题库 iOS 客户端架构设计 序 猿题库是一个拥有数千万用户的创业公司,从2013年题库项目起步到2015年,团队保持了极高的生产效率,使我们的产品完成了五个大版本和数十个小版本的高速迭代.在如此快 ...

  5. Ocr答题辅助神器 OcrAnswerer4.x,通过百度OCR识别手机文字,支持屏幕窗口截图和ADB安卓截图,支持四十个直播App,可保存题库

    http://www.cnblogs.com/Charltsing/p/OcrAnswerer.html 联系qq:564955427 最新版为v4.1版,开放一定概率的八窗口体验功能,请截图体验(多 ...

  6. NOI题库刷题日志 (贪心篇题解)

    这段时间在NOI题库上刷了刷题,来写点心得和题解 一.寻找平面上的极大点 2704:寻找平面上的极大点 总时间限制:  1000ms  内存限制:  65536kB 描述 在一个平面上,如果有两个点( ...

  7. NOI题库 1768最大子矩阵 题解

    NOI题库 1768最大子矩阵  题解     总时间限制: 1000ms 内存限制: 65536kB   描述   已知矩阵的大小定义为矩阵中所有元素的和.给定一个矩阵,你的任务是找到最大的非空(大 ...

  8. NOI题库 09:图像旋转翻转变换

    NOI题库开始的题,也是略水,当然也是大水,所以彼此彼此 09:图像旋转翻转变换 总时间限制: 1000ms 内存限制: 65536kB 描述 给定m行n列的图像各像素点灰度值,对其依次进行一系列操作 ...

  9. NOI题库-小学奥赛QwQ

    今天Loli教育我们让我们来看看NOI题库的奥赛部分,不过,为何是小学的( ⊙ o ⊙ )啊!感觉智商被各种侮辱. 余数相同问题: 描述 已知三个正整数 a,b,c. 现有一个大于1的整数x,将其作为 ...

随机推荐

  1. 南阳219----An problem about date

    /* 1600年一月一日为星期6,所以算出ymd与1600-1-1差多少天对7取余即可 */ #include<stdio.h> ]={}; int main() { ,ans; ; i& ...

  2. 解决Python自带的json不能序列化data,datetime类型数据问题

    官方文档中的一个Demo: >>> import json >>> class ComplexEncoder(json.JSONEncoder): ... def ...

  3. 第13届景驰-埃森哲杯广东工业大学ACM程序设计大赛.B.跳一跳,很简单的(Hash 倍增)

    题目链接 首先变换的周期是\(26\),而所有字符是同时变的,所以一共就只有\(26\)种树,我们对\(26\)棵树分别处理. 求某节点到根路径上的字符串,可以从根往下哈希,\(O(n)\)预处理出. ...

  4. 利用api模拟百度搜索功能

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. MPU和CPU有什么区别?

    MPU(或称MP,微处理器)和CPU(中央处理器)同为处理器,但范畴不同. 计算机(即电脑)分为巨型机,大型机,中型机,小型机和微型计算机5类.这5类计算机的运算核心统称为CPU,而MPU只是微型计算 ...

  6. 基于socketserver模块并发套接字

    1.基于tcp协议 服务端: import socketserverclass MyHandler(socketserver .BaseRequestHandler ): def handle(sel ...

  7. [P2850][USACO06DEC]虫洞Wormholes (最短路)

    死活调不出来 后来是发现这题建边的原因…… 吐血.jpg 所谓的虫洞传说也就是负边了 然后这里打的spfa和原来的不一样 感觉hzwer大佬的spfa好强啊…… 也更易写一点 贴代码 #include ...

  8. redis(一)

    NoSQL简介 NoSQL,全名为Not Only SQL,指的是非关系型的数据库 随着访问量的上升,网站的数据库性能出现了问题,于是nosql被设计出来 优点/缺点 优点: 高可扩展性 分布式计算 ...

  9. python正则表达式(四)

    re模块的高级用法 search 需求:匹配出文章阅读的次数 #coding=utf-8 import re ret = re.search(r"\d+", "阅读次数为 ...

  10. .net异常机制

    异常机制简介 当CPU运行到一些非法的指令,例如除零错误,访问内存页失败等指令,CPU会生成一个硬件异常,不同的异常有固定的异常代码作为标识符,异常产生以后CPU暂时不能继续执行后续的指令—因为后续的 ...