QCon 演讲火热征集中,快来分享你的技术实践与洞见! 了解详情
写点什么

代码行数减少 30-90%!多邻国从 Java 迁移到 Kotlin 的奇妙体验

  • 2020-04-24
  • 本文字数:2203 字

    阅读完需:约 7 分钟

代码行数减少30-90%!多邻国从Java迁移到Kotlin的奇妙体验

英文学习 App Duolingo(多邻国)的 Android 版最初是使用 Java 开发的,并一直沿用了 5 年。两年后,它变成了 100% 的 Kotlin App!从代码可维护性和开发者满意度方面来看,这次迁移是一个巨大的成功。 网上已经有很多 Kotlin 的学习资源,所以在这篇文章中,我们将重点介绍如何将一个有百万用户的 App 迁移到 Kotlin。


为什么选择 Kotlin

2018 年初,我们开始考虑使用 Kotlin,当时 Android 对 Kotlin 的支持还不到一年时间,而且不知道 Kotlin 会像现在这样流行,也不知道它会取代 Java 成为 Android 的开发首选语言。


我们当时的主要预期:


  • 生产力。Kotlin 比 Java 要简洁得多,编写 Kotlin 代码速度更快,维护起来也更容易。它与 Java 的无缝互操作性以及添加语言新特性的方式让 Android 开发者可以轻松上手。

  • 稳定性。我们的代码库历史记录中有 100 多次提交都与“修复 NullPointerException 问题”有关,这些问题都来自 Java 代码。Kotlin 的 Null 安全特性避免了大部分 NullPointerException,让我们在代码评审期间可以更多地关注其他问题。

  • 开发者满意度。Stack Overflow 发布的 2018 年度开发者编程语言报告表明,Kotlin 是开发者最喜爱的编程语言之一,仅次于 Rust。我们的开发人员已经对公司内部另外两个主要平台的语言升级做出了积极的反应:在 iOS 应用程序中使用 Swift,以及使用 TypeScript 完全重写了 duolingo.com。


当然,迁移也存在一些风险,主要是开发人员的时间成本问题。另一个担忧是 Kotlin 是否会像 CoffeeScript 一样,最后可能会被它的“影子”语言打败。


最后,我们的 Android 开发人员一致认为,Kotlin 的好处很有价值,足以证明使用 Kotlin 开发新代码是合理的,尽管我们还没有准备好全面迁移所有的代码。

让开发人员跟上进度

Duolingo 的所有 Android 开发人员每两周开一次例会,讨论最近和即将做出的平台变更和非正式的事后分析,并进行问答。前期的会议专门介绍 Kotlin,内容主要基于 Kotlin 官方语言指南、Kotlin Koans、Android 官方文档和 MindOrks 备忘单,等等。


然后,每个 Android 开发人员都分配到一些 Java 代码,负责将它们迁移到 Kotlin。我们让相对有 Kotlin 经验的开发人员担任“Kotlin checker”角色,让他们在代码评审期间分享最佳实践。这个角色的人数逐步增加,直到所有的 Android 开发人员都包含在内。

Kotlin 相关的开发工具

从一开始,我们就对 Kotlin 工具进行容器化,并在代码预提交和 GitHub 拉取请求状态检查中强制使用,以此来确保代码的一致性。


我们使用 detekt、IntelliJ Inspection、Android lint 和我们自己开发的基于正则表达式的 Splinter 来检查所有的 Kotlin 代码。


在代码自动格式化方面,我们在公司范围内使用了 ktlint,将其作为代码预提交 hook 的一部分。另一个工具是 IntelliJ Formatter,不过我们发现它在 Docker 中运行会慢一些。


在将 Java 代码减少到只有 10% 的时候,我们从 CI 管道中移除了 PMD、SpotBugs 和大部分检查工具。继续使用这些 Java 工具将会降低我们的开发速度,而且不会为我们提供太多的价值。

转换 Java 代码

为了让代码转换的评审工作尽可能轻松,我们建议每个源文件的拉取请求至少包含三个单独的提交:


  • 运行 IDE 的自动转换器。这个提交会造成代码行错乱,但不需要仔细检查,因为对于运行时来说通常是安全的,尽管可能会引入编译时错误。

  • 修复编译错误。这些修复通常很容易进行,例如,在必要时添加 @JvmStatic 注解。

  • 重构。开发人员需要重构代码,让代码更符合 Kotlin 的习惯,例如使用 sumBy 而不是 for 循环。


我们发现,将 Java 文件转换成 Kotlin 后,行数平均减少了 30% 左右,在某些情况下甚至减少了 90%!


虽然移植代码对于我们的 Android 平台工程师来说不是问题,但对于我们的产品团队来说可能会相对困难。我们鼓励产品团队的开发人员在空闲时间迁移经常修改的代码,还通过每天的排行榜比赛来游戏化这个过程。最终,产品团队的开发人员担起了一半的工作量。

绊脚石

Kotlin 的工具生态系统比 Java 的要小得多。尽管如此,它已经足够满足我们的需求了。


我们偶尔还是会遇到 NullPointerException 和 IllegalArgumentException,这些异常来自第三方 Java 依赖库(比如 Android 框架本身),它们没有遵循最佳实践,没有使用可空注解,以至于 Kotlin 编译器无法知道某些方法的参数或返回值可以为空。随着谷歌给它们的公共 API 加入注解,这种情况得到了改善。


不过,Kotlin 仍然缺乏对一些 Java 特性的原生支持,包括不太常见的超类静态受保护方法调用和神秘的超类构造函数调用,但这类问题很容易解决。

结果

在 2018 年初引入 Kotlin 之前,我们的 Android 代码库的代码行数每年增长 46%。两年过去了,我们加入了很多新特性,活跃的贡献者数量增加了一倍多,而我们的代码库现在几乎只和以前一样大!


根据 NPS 数据,这一次 Android 开发人员的满意度增加了 129 个点,大多数开发人员认为是采用 Kotlin(以及我们的工具)起到了主要作用。NPS 的数据具体为:


https://en.wikipedia.org/wiki/Net_Promoter


我们现在也同时使用 Python 和 Java 作为后端服务开发语言,这几乎不需要额外的工作量,因为我们可以重用现有服务中的 Java 代码和 Android 代码库中的 Kotlin 工具。


总的来说,在迁移到 Kotlin 之后,我们感到非常开心。我们也很高兴能够看到它在我们的公司内部和整个软件行业中的采用率不断增长!

英文原文

Migrating Duolingo’s Android App to 100 Kotlin


2020-04-24 16:375341
用户头像
小智 让所有人认同的文字称不上表达

发布了 408 篇内容, 共 391.5 次阅读, 收获喜欢 1982 次。

关注

评论

发布
暂无评论
发现更多内容

光纤的跳线和尾纤

小齐写代码

夏志刚介绍

管理在线

企业战略管理体系 企业精益管理体系 企业创新管理类体系 企业培训体系 企业标准化管理体系

CDP技术系列(二):ClickHouse+Bitmap实现海量数据标签及群体组合计算

京东科技开发者

数值计算: 精度、溢出、舍入

西格玛

K8s集群CoreDNS监控告警最佳实践

华为云开发者联盟

开发 华为云 k8s集群 华为云开发者联盟

CDP技术系列(三):百万级QPS的人群命中服务接口性能优化指南

京东科技开发者

融合创新:传统企业数字化转型的业务、战略、操作和文化变革

天津汇柏科技有限公司

数字化转型

Kube Queue:Kubernetes 任务排队的利器

阿里巴巴云原生

阿里云 Kubernetes Kuber 云原生

如何从 Jira 成功迁移到极狐GitLab,看这个就够了!

极狐GitLab

DRM音频格式转换好帮手-NoteBurner iTunes DRM Audio Converter 兼容M1和macos14系统

Rose

DRM 音频转换器

有挑战才有收获!PaddleOCR算法模型挑战赛火热开启!

飞桨PaddlePaddle

人工智能 算法 大赛 百度飞桨 算法模型

【Linux技术专题】「夯实基本功系列」带你一同学习和实践操作Linux服务器必学的Shell指令(排查问题指令 - 下)

洛神灬殇

Linux 日志处理 Shell指令 查询日志 2024年第二十篇文章

BricsCAD 24 mac中文完美破解版(CAD建模软件) 支持M和 macOS Sonoma 14 附安装教程

Rose

BricsCAD 23中文版 cad bricscad 24 BricsCAD 24破解版 BricsCAD 24下载

一篇全掌握!TDengine 在能源、电力、汽车、物流、工业制造等十大行业应用合集

TDengine

tdengine 时序数据库

用Python实现高效数据记录!Web自动化技术助你告别重复劳动!

测试人

软件测试

Programming Abstractions in C阅读笔记:p248-p253

codists

左耳听风 - 时间管理「读书打卡 day 15」

Java 工程师蔡姬

读书笔记 程序员 个人成长 时间管理 职业发展

2024-01-24:用go语言,已知一个n*n的01矩阵, 只能通过通过行交换、或者列交换的方式调整矩阵, 判断这个矩阵的对角线是否能全为1,如果能返回true,不能返回false。 我们升级一下:

福大大架构师每日一题

福大大架构师每日一题

什么是网络地址转换协议

郑州埃文科技

应用监控 eBPF 版:实现高效协议解析的技术探索

阿里巴巴云原生

阿里云 云原生 可观测

CDP技术系列(一):使用bitmap存储数十亿用户ID的标签或群体

京东科技开发者

uniapp+unicloud开发一个网页端,小程序端,APP端,桌面端的博客CMS系统——万能的三三

万能的三三

JavaScript 小程序 uni-app CMS 博客

Mac上超好用的鼠标平滑滚动增强工具:SmoothScroll

Rose

Mac软件 鼠标工具 SmoothScroll 平滑滚动

数仓如何递归查询视图依赖

华为云开发者联盟

数据库 后端 华为云 华为云开发者联盟 华为云GaussDB(DWS)

权威媒体评选:2023年25个最佳开源软件

SEAL安全

开源 AI LLMs

云原生网关哪家强:Sealos 网关血泪史

阿里巴巴云原生

阿里云 云原生 Sealos

Live Home 3D Pro for Mac(苹果电脑3D室内家居设计软件)

Rose

Mac软件 Live Home 3D Pro 家居设计软件 Live Home 室内设计

mac系统u盘启动盘制作教程,更新至macOS Sonoma 14

Rose

mac系统

代码行数减少30-90%!多邻国从Java迁移到Kotlin的奇妙体验_移动_Art Chaidarun_InfoQ精选文章