0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

将其Android应用的Java代码迁移到Kotlin

OSC开源社区 来源:OSC开源社区 作者:OSC开源社区 2022-10-28 15:15 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

Meta 发布了一篇博客表示,正在将其 Android 应用的 Java 代码迁移到 Kotlin,并分享了这一过程中的一些经验。

该公司认为,Kotlin 是一种流行的 Android 开发语言,与 Java 相比具有一些关键优势。“因此,在我们努力使我们的开发工作流程更加高效的过程中,将 Meta 的 Android 开发转向 Kotlin 是非常合理的。..。..Kotlin 通常被认为是一种比 Java 更好的语言,在年度 Stack Overflow 开发者调查中,它的好感度要高于 Java。”

除了受欢迎程度外,Meta 还将最新的 Kotlin 版本与 Java 11(可用于 Android 开发的最新版本)进行了比较,并得出了 Kotlin 的一些主要优势:可空性、函数式编程、更短的代码、以及领域特定语言 (DSL) / 类型安全构建器等。

Facebook 软件工程师 Omer Strulovich 指出,Meta 旗下几个流行的 Android 应用 --Facebook、Instagram、Messenger、Portal 和 Quest 都已经开始从 Java 转向 Kotlin。截至目前,Facebook、Messenger 和 Instagram 的 Android 应用程序都有超过 100 万行 Kotlin 代码,并且转换率正在提高。Meta 的 Android 代码库总共已包含有超过 1000 万行的 Kotlin 代码。作为此次迁移的一部分,Meta 透露其也正在开源用于操作 Kotlin 代码的各种示例和实用程序。

不过,采用 Kotlin 也有一些不能忽视的缺点。博客内容指出,比如:两种语言的混合代码库需要长时间的处理维护;以及 Kotlin 与 Java 相比,流行度还是存在明显的差距,这意味着 Kotlin 可用的工具也更少。更糟糕的是所有 Kotlin 工具还都需要考虑 Kotlin 和 Java 的互操作性,这使得它们的实现就变得复杂。

最大的问题还在于构建时间。“我们从一开始就知道 Kotlin 的构建时间会比 Java 的要长。该语言及其生态系统更加复杂,Java 在优化其编译器方面领先了 20 年。由于我们拥有多个大型应用程序,较长的构建时间可能会对我们的开发人员体验产生负面影响。”

如何处理迁移

Meta 称,迁移到 Kotlin 既简单又非常复杂。因为 Kotlin 的设计允许从 Java 进行简单的转换,并具有经过深思熟虑的互操作性。这种设计使 JetBrains 能够为开发人员社区提供 J2K,即 IntelliJ/Android Studio 中的 Java 到 Kotlin 转换器。但 J2K 不是万能的,迁移中的有些情况仍然很复杂。

迁移之前,该公司考虑了两个选择:

一个是可以使用 Kotlin 在 Meta 上编写新代码,但将大部分现有代码保留在 Java 中。

还有一个是可以尝试将几乎所有内部代码转换为 Kotlin。

第一个选项的优势很明显,即少得多的工作量;但是这种方法也有两个明显的缺点。首先,在 Kotlin 和 Java 代码之间实现互操作性引入了 Kotlin 中 platform types 的使用。platform types 会导致运行时空指针取消引用,从而导致崩溃,破坏了纯 Kotlin 代码提供的静态安全优势。在一些复杂的情况下,Kotlin 的空检查省略还可能漏掉空值通过,进而引发空指针异常。例如,如果 Kotlin 代码调用由 Java 接口实现的 Kotlin 接口,就会发生这种情况。其他问题包括 Java 无法将类型参数标记为可空性(直到最近才修复),以及 Kotlin 的重载规则考虑了可空性,而 Java 的重载规则却没有。

第二个缺点是考虑到 Meta 的大多数软件开发都需要修改现有代码。“如果我们的大部分代码都是用 Java 编写的,我们就无法让我们的开发人员充分享受 Kotlin 的乐趣。由于迁移是一个漫长的过程,期望每个工程师在接触文件之前将文件转换为 Kotlin 既费力又低效。”

因此,Meta 方面最终选择了第二条选项,决定将几乎所有代码转换为 Kotlin。而在尝试为现有应用程序引入 Kotlin 时,Meta 也遇到了很多麻烦,例如需要更新 Redex 以支持 Java 不生成的字节码模式。以及使用的某些内部库依赖于在编译期间进行字节码转换来获取更好的性能。而将其作为 Kotlin 编译的一部分运行时,这部分代码则无法生效。为此,Meta 专门构建了解决工具。

此外,他们还发现在现有工具中存在的一些差异。例如代码审查或 wiki 中缺少 Kotlin 语法高亮显示。“我们更新了我们正在使用的库 Pygments,以使体验与 Java 相媲美。我们更新了一些内部代码修改工具,以便能够处理 Kotlin。我们还构建了 Ktfmt,这是一个基于 google-java-format 的代码和理念的确定性 Kotlin 格式化程序。”

准备好所有工具后,Meta 就可以正式开始批量转换大量代码。“随着我们工具的改进,我们已经能够将相当大的一部分代码转换成 Kotlin。我们的代码库中已经有超过 1000 万行 Kotlin 代码,而且 Meta 的大多数 Android 开发人员现在都在编写 Kotlin 代码”。平均而言,此次迁移使代码行数减少了 11%。

Meta 方面表示,其向 Kotlin 的迁移仍在进行中并在加速。“我们已经允许 Meta 的任何想要使用 Kotlin 的 Android 开发人员这样做,并为他们提供了工具来轻松地将现有代码迁移到 Kotlin。Kotlin 仍然缺少一些我们在使用 Java 时已经习惯的工具和优化。但我们正在努力缩小这些差距。随着我们取得进展以及这些工具和库的成熟,我们还将努力将它们反馈给社区。”

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Android
    +关注

    关注

    12

    文章

    3986

    浏览量

    133093
  • JAVA
    +关注

    关注

    20

    文章

    2997

    浏览量

    115703
  • 代码
    +关注

    关注

    30

    文章

    4942

    浏览量

    73160

原文标题:已超1000万行代码,Java再次输给了Kotlin...

文章出处:【微信号:OSC开源社区,微信公众号:OSC开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    无质量损失的数据迁移:Nikon SLM Solutions信赖3Dfindit企业版

    使用转换器将CAD数据从一个系统传输到另一个系统,但这往往会导致数据的质量下降。因此,该公司决定使用3Dfindit企业版将CAD数据迁移到新系统,便不会造成任何质量损失。这样,在保持最高数据质量
    发表于 11-25 10:06

    如何基于开发板RK3568 Android 11强制所有应用横屏展示

    RK3568 Android 11强制所有应用横屏展示,1、打开frameworks/base/core/java/android/content/pm/parsing/component
    的头像 发表于 11-07 16:07 569次阅读
    如何基于开发板RK3568 <b class='flag-5'>Android</b> 11强制所有应用横屏展示

    Arm Neoverse CPU上大代码Java应用的性能测试

    Java 是互联网领域广泛使用的编程语言。Java 应用的一些特性使其性能表现与提前编译的原生应用(例如 C 程序)大相径庭。由于 Java 字节码无法直接在 CPU 上执行,因此通常运行时在
    的头像 发表于 11-05 11:25 386次阅读
    Arm Neoverse CPU上大<b class='flag-5'>代码</b>量<b class='flag-5'>Java</b>应用的性能测试

    Java 25正式发布,重要特性详解(附代码示例):灵活构造函数体、模块导入声明、AOT方法分析等

    Java 25现已发布,更多新特性来了!配合Perforce JRebel,代码修改即时生效,无需重启服务,即可实现“改完就看效果”。新特性+快工具,让你的Java开发体验双倍提升!
    的头像 发表于 10-29 13:16 878次阅读
    <b class='flag-5'>Java</b> 25正式发布,重要特性详解(附<b class='flag-5'>代码</b>示例):灵活构造函数体、模块导入声明、AOT方法分析等

    如何在Keil中将NuMicro BSP从Arm编译器5迁移到编译器6?

    在Keil中将NuMicro BSP从Arm编译器5迁移到编译器6!
    发表于 08-20 06:29

    Perforce JRebel 简介:即时加载代码变更,加速Java应用开发

    Perforce JRebel 专为Java开发提速而生!支持跳过构建与重新部署,实时加载代码变更,支持100+框架,无缝集成主流IDE与应用服务器。
    的头像 发表于 08-14 14:35 494次阅读
    Perforce JRebel 简介:即时加载<b class='flag-5'>代码</b>变更,加速<b class='flag-5'>Java</b>应用开发

    ArkUI-X与Android消息通信

    ) => { console.log(\'error: \' + JSON.stringify(err)); }); 2.Android侧接收来自ArkUI侧的数据。 // xxx.java
    发表于 06-08 22:15

    Kuikly鸿蒙版正式开源 —— 揭秘卓越性能适配之旅

    、小程序Q2开源) 原生级性能体验:得益于 KMP 跨平台能力,Kuikly 将 Kotlin 代码编译成各个平台原生产物,从而获得接近原生平台的执行性能。 Kotlin语言驱动,纯原生开发工具链:复用
    发表于 06-04 16:46

    从Keil MDK到IAR EWARM:通过工程迁移实现项目资产的更好管理

    对于需要统一开发环境或涉及多核架构(如Cortex-A/R)的项目,越来越多的用户选择从Keil MDK迁移到IAR EWARM。这就会面临着需要将之前的Keil MDK工程迁移到IAR EWARM的问题。本文将介绍如何高效完成这一迁移
    的头像 发表于 05-08 09:03 1007次阅读
    从Keil MDK到IAR EWARM:通过工程<b class='flag-5'>迁移</b>实现项目资产的更好管理

    Java开发者必备的效率工具——Perforce JRebel是什么?为什么很多Java开发者在用?

    Perforce JRebel是一款Java开发效率工具,旨在帮助java开发人员更快地编写更好的应用程序。JRebel可即时重新加载对代码的修改,无需重启或重新部署应用程序,就能让开发者即时看到
    的头像 发表于 04-27 13:44 659次阅读
    <b class='flag-5'>Java</b>开发者必备的效率工具——Perforce JRebel是什么?为什么很多<b class='flag-5'>Java</b>开发者在用?

    请问将项目从RT1024迁移到RT1064的最快方法是什么?

    我正在将我的项目从基于 RT1024 迁移到基于 RT1064 的下一代产品,是否有快速的方法,或者我只能手动完成? 谢谢!
    发表于 03-31 06:15

    如何将项目从IAR迁移到Embedded Studio

    本文描述如何将IAR EWARM项目迁移到SEGGER Embedded Studio(简称SES)中。
    的头像 发表于 02-25 17:11 1070次阅读
    如何将项目从IAR<b class='flag-5'>迁移到</b>Embedded Studio

    Spire.XLS for Android via Java组件说明

    Spire.XLS for Android via Java 是一款专业的 Android Excel 组件,用于在 Android 手机应用程序中创建、操作和转换 Excel 工作表
    的头像 发表于 01-24 12:16 825次阅读
    Spire.XLS for <b class='flag-5'>Android</b> via <b class='flag-5'>Java</b>组件说明

    AKI跨语言调用库神助攻C/C++代码迁移至HarmonyOS NEXT

    /C++代码快速迁移至HarmonyOS NEXT。凭借卓越的兼容性,AKI已成为厂商与开发者打造鸿蒙原生应用过程中广泛使用的跨语言调用解决方案。 AKI是一款专为鸿蒙原生开发设计的FFI(外部函数接口
    发表于 01-02 17:08

    龙智直播预告:揭示现代化数据管理与版本控制优势、从SVN迁移到Helix Core的实践指导、迁移步骤等

    2025年1月9日(周四)14:00-14:45,Perforce中国授权合作伙伴-龙智将在线直播,分享为何您的传统数据管理与版本控制系统需要升级、Perforce Helix Core的显著优势,以及如何迁移到Helix Core等实用见解,以为您的数据管理与版本控制系统现代化转型提供有力支持。
    的头像 发表于 12-16 15:35 628次阅读
    龙智直播预告:揭示现代化数据管理与版本控制优势、从SVN<b class='flag-5'>迁移到</b>Helix Core的实践指导、<b class='flag-5'>迁移</b>步骤等