猿题库从 Objective-C 到 Swift 的迁移
猿题库从 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 的迁移的更多相关文章
- 猿题库 iOS 客户端架构设计
原文: http://mp.weixin.qq.com/s?__biz=MjM5NTIyNTUyMQ==&mid=444322139&idx=1&sn=c7bef4d439f4 ...
- 猿题库 iOS 客户端架构设计-唐巧
序 猿题库是一个拥有数千万用户的创业公司,从20013年题库项目起步到2015年,团队保持了极高的生产效率,使我们的产品完成了五个大版本和数十个小版本的高速迭代. 在如此快速的开发过程中,如何保证代码 ...
- 【android】如何实现猿题库题目的排版
最近我们的产品来了个新的模块,类似猿题库一样,给学生做题提高成绩的. 要求如下: 1:支持单选.多选.填空题 2:支持图片文字混排 3:输入框有交互,排版精致美观 4:为了体验优化,不能使用网页实现效 ...
- 猿题库 iOS 客户端架构设计(原文地址:http://gracelancy.com/blog/2016/01/06/ape-ios-arch-design/)
猿题库 iOS 客户端架构设计 序 猿题库是一个拥有数千万用户的创业公司,从2013年题库项目起步到2015年,团队保持了极高的生产效率,使我们的产品完成了五个大版本和数十个小版本的高速迭代.在如此快 ...
- Ocr答题辅助神器 OcrAnswerer4.x,通过百度OCR识别手机文字,支持屏幕窗口截图和ADB安卓截图,支持四十个直播App,可保存题库
http://www.cnblogs.com/Charltsing/p/OcrAnswerer.html 联系qq:564955427 最新版为v4.1版,开放一定概率的八窗口体验功能,请截图体验(多 ...
- NOI题库刷题日志 (贪心篇题解)
这段时间在NOI题库上刷了刷题,来写点心得和题解 一.寻找平面上的极大点 2704:寻找平面上的极大点 总时间限制: 1000ms 内存限制: 65536kB 描述 在一个平面上,如果有两个点( ...
- NOI题库 1768最大子矩阵 题解
NOI题库 1768最大子矩阵 题解 总时间限制: 1000ms 内存限制: 65536kB 描述 已知矩阵的大小定义为矩阵中所有元素的和.给定一个矩阵,你的任务是找到最大的非空(大 ...
- NOI题库 09:图像旋转翻转变换
NOI题库开始的题,也是略水,当然也是大水,所以彼此彼此 09:图像旋转翻转变换 总时间限制: 1000ms 内存限制: 65536kB 描述 给定m行n列的图像各像素点灰度值,对其依次进行一系列操作 ...
- NOI题库-小学奥赛QwQ
今天Loli教育我们让我们来看看NOI题库的奥赛部分,不过,为何是小学的( ⊙ o ⊙ )啊!感觉智商被各种侮辱. 余数相同问题: 描述 已知三个正整数 a,b,c. 现有一个大于1的整数x,将其作为 ...
随机推荐
- Jmeter压测过程报错the target server failed to respond
失败事务报错信息如下, Socket closed Non HTTP response code: org.apache.http.NoHttpResponseException (the targe ...
- 南阳325----zb的生日
//重量太大,用01背包容易超时 //数据只有20组.可以用dfs搜索最优解 #include<stdio.h> ]; int maxs,n,s; void dfs(int,int); i ...
- 第二章 《C++ Primer Plus》
第二章: 让窗口暂停: cin.get(); 作为接口的函数头: 函数头句法: 函数头描述了函数与调用它的函数之间的接口. int main(); int main(void); return 0; ...
- Bridges: The Final Battle
对修改操作按时间分治,设$solve(l,r,n,m)$为考虑时间在$[l,r]$的修改操作,作用范围是$n$个点,$m$条边的图. 若$l=r$,则暴力Tarjan统计桥边个数即可. 否则提取出$[ ...
- 树莓派mariadb折腾
今天在树莓派之中安装mysql,结果被我安装了mariadb,这样做很讨厌,但是也可以将就用.记录一下折腾的过程. 安装就还是使用sudo apt install mysql 1.安装之后需要使用工具 ...
- spring项目出现无法加载主类
问题:eclipse总是运行之前的项目,新改变的项目内容,不运行.于是我想要是清理缓存,网上说project--->clean指定的项目就可以 但是clean后就无法加载主类了,项目上还出现了红 ...
- windows下安装mysql遇到的问题
windows下安装mysql5.6.41步骤:http://www.cnblogs.com/sjy18039225956/p/9203052.html 系统错误2详见MySQL安装过程net sta ...
- PAT Basic 1012
1012 数字分类 (20 分) 给定一系列正整数,请按要求对数字进行分类,并输出以下 5 个数字: A1 = 能被 5 整除的数字中所有偶数的和: A2 = 将被 5 除后余 1 的数字 ...
- 分享一个整理Mac储存空间的软件,有效清理xcode的垃圾
苹果的电脑还是比windows的要好,我这台用了3年时间,作为编程工作天天用,现在愣是一点儿也没有卡顿,如果换作是windows的电脑,我敢保证肯定是卡成狗,相信做编程的你肯定少补了一台mac. ma ...
- @RequestBody, @ResponseBody 注解详解(转)
原文地址: https://www.cnblogs.com/qq78292959/p/3760651.html @RequestBody, @ResponseBody 注解详解(转) 引言: 接上一篇 ...