-
稳定性。我们的代码库历史记录中有 100 多次提交都与“修复 NullPointerException 问题”有关,这些问题都来自 Java 代码。Kotlin 的 Null 安全特性避免了大部分 NullPointerException,让我们在代码评审期间可以更多地关注其他问题。
-
开发者满意度。Stack Overflow 发布的 2018 年度开发者编程语言报告表明,Kotlin 是开发者最喜爱的编程语言之一,仅次于 Rust。我们的开发人员已经对公司内部另外两个主要平台的语言升级做出了积极的反应:在 iOS 应用程序中使用 Swift,以及使用 TypeScript 完全重写了 duolingo.com。
-
当然,迁移也存在一些风险,主要是开发人员的时间成本问题。另一个担忧是 Kotlin 是否会像 CoffeeScript 一样,最后可能会被它的“影子”语言打败。
-
最后,我们的 Android 开发人员一致认为,Kotlin 的好处很有价值,足以证明使用 Kotlin 开发新代码是合理的,尽管我们还没有准备好全面迁移所有的代码。
2. 让开发人员跟上进度
Duolingo 的所有 Android 开发人员每两周开一次例会,讨论最近和即将做出的平台变更和非正式的事后分析,并进行问答。前期的会议专门介绍 Kotlin,内容主要基于 Kotlin 官方语言指南、Kotlin Koans、Android 官方文档和 MindOrks 备忘单,等等。
然后,每个 Android 开发人员都分配到一些 Java 代码,负责将它们迁移到 Kotlin。我们让相对有 Kotlin 经验的开发人员担任“Kotlin checker”角色,让他们在代码评审期间分享最佳实践。这个角色的人数逐步增加,直到所有的 Android 开发人员都包含在内。
3. Kotlin 相关的开发工具
从一开始,我们就对 Kotlin 工具进行容器化,并在代码预提交和 GitHub 拉取请求状态检查中强制使用,以此来确保代码的一致性。
我们使用 detekt、IntelliJ Inspection、Android lint 和我们自己开发的基于正则表达式的 Splinter 来检查所有的 Kotlin 代码。
在代码自动格式化方面,我们在公司范围内使用了 ktlint,将其作为代码预提交 hook 的一部分。另一个工具是 IntelliJ Formatter,不过我们发现它在 Docker

(编辑:长春站长网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|