低代码到底是不是行业毒瘤?一线大厂怎么做的?戳此了解>>> 了解详情
写点什么

Java 失宠,谷歌宣布 Kotlin 现在是 Android 开发的首选语言

2019 年 5 月 08 日

Java失宠,谷歌宣布Kotlin现在是Android开发的首选语言

在今日凌晨的 Google I/O 大会上,Google 官方正式宣布,Kotlin 编程语言现在是 Android 应用程序开发人员的首选语言。Java 占据 Android 开发绝对统治的时代一去不复返了。


Kotlin,东宫太子

谷歌今天宣布,Kotlin 编程语言现在是 Android 应用程序开发人员的首选语言。


谷歌在今天的声明中写道:“Android 的开发将越来越以 Kotlin 为先。”许多新的 Jetpack API 和特性将首先在 Kotlin 中提供。如果你要开始一个新项目,你应该用 Kotlin 来写;用 Kotlin 编写通常意味着更少的代码——更少用于类型、测试和维护方面的代码。”


就在两年前的 2017 年 I/O 大会上,谷歌宣布在其 Android Studio IDE 中支持 Kotlin。考虑到 Java 长期以来一直是 Android 应用程序开发的首选语言,这有点令人惊讶。在过去的两年里,Kotlin 的人气只增不减。谷歌说,超过 50%的专业 Android 开发人员现在使用该语言开发他们的应用程序,在最新的 Stack Overflow 开发人员调查中,它被列为第四大最受欢迎的编程语言。



Android 的首席倡导者切特·哈斯(Chet Haase)表示:“我们宣布,我们正在采取的下一个重大举措是,我们将以 Kotlin 为先。”


哈斯说:“我们知道,不是每个人现在都在用 Kotlin,但是我们相信,你会需要它的。”“你可能有充分的理由继续使用 C++和 Java 编程语言,这完全没问题。这些语言不会消失。”


Kotlin,Android 世界的 Swift?

早在 2015 年,Kotlin 就有“Android 世界的 Swift ”的称号。


Kotlin 是一门与 Swift 类似的静态类型 JVM 语言,由 JetBrains 设计开发并开源。与 Java 相比,Kotlin 的语法更简洁、更具表达性,而且提供了更多的特性,比如,高阶函数、操作符重载、字符串模板。它与 Java 高度可互操作,可以同时用在一个项目中。


按照 JetBrains 的说法,根据他们多年的 Java 平台开发经验,他们认为 Java 编程语言有一定的局限性和问题,而且由于需要向后兼容,它们不可能或很难得到解决。因此,他们创建了 Kotlin 项目,主要目标是:


  • 创建一种兼容 Java 的语言

  • 编译速度至少同 Java 一样快

  • 比 Java 更安全

  • 比 Java 更简洁

  • 比最成熟的竞争者 Scala 还简单


若在当时看来,Android 世界的 Swift 称号似乎底气不足,更像是一种美好的愿望。那么在 2017、2019 两届的 Google I/O 以后,这个说法可以站住脚了。


Kotlin 真比 Java 强?

许多新语言的出现似乎都是源于对某种其它语言的厌倦。似乎 Kotlin 也是如此。但在 JetBrains 看来,Kotlin 项目的原始动机就是为了提升生产力。JetBrains 开发者支持组组长 Hadi Hariri 在接受 InfoQ 采访时表示:


”尽管当时我们已经开发了对几种基于 JVM 的编程语言的支持,我们还是基本都在 Java 环境下写基于 IntelliJ 的 API。IntelliJ 开发系统是基于 Groovy 和 Gant 的,Groovy 也用于测试,RubyMine 中还有一些 JRuby 代码,情况就是如此。我们希望转向更具表现力的语言从而提高生产力。同时,我们不能接受在 Java 互操作性或编译速度方面的妥协。“


Kotlin 与 Java 总是在主观比较

“Kotlin 比 Java 好”,“Kotlin 可读性比 Java 强”,“Kotlin 开发速度比 Java 快”,类似这样的陈述缺少相关准确数据的支持,所以都归为主观看法一类。


主观看法是个体开发人员在对与 Kotlin 或 Java 相关的主题作出一个或多个主观判断时形成。


开发人员的主观判断存在如下问题:


  • 没有与主观判断相关联的量化指标。

  • 主观判断存在很大的偏见。

  • 主观判断的偏见在开发人员之间存在很大的差异。


由于没有与主观判断相关联的量化指标,建立在这些判断基础上的观点只是反映出了开发人员之前就有的偏见。不同的开发人员可能有着截然不同的偏见,因此,有开发人员认为 Kotlin 是不错(或糟糕)的 Java 替代者并不意味着其他开发人员也这么认为。


而且,由于没有客观指标,主观分歧就无法客观地消除,这经常会导致“口水战”。


相较于 Java,Kotlin 的确在一些方面有较大优势:效率高、易维护、可靠、简单易学。在一些特定场景下,许多 Java 开发者因为某些方面的问题选择了切换到 Kotlin:比如受够了 Java NullPointerException 的人都喜欢 Kotlin 的 Null 安全特性;扩展函数被大量使用;除了扩展 Java 类,人们也常常将 Java 代码迁移到 Kotlin。


根据英国软件公司 Pusher 调查的数据显示,在样本数 2744 人的调查中,超过 87% 的受调者已经完成了迁移。他们有的使用了迁移向导,有的直接手动修改代码。超过四分之一的受调者迁移到 Kotlin 后又回到了 Java。有技术方面的原因,也有组织方面的原因。其中使用了反射或代码生成的工具是被提及最多的因素。


  • “Kotlin 的枚举不能包含常量。在自定义注解时(比如 @IntDef),为了保持接口的整洁,需要将值保存在枚举中。”

  • “我们正在使用 Realm,但它不能与数据类一起使用。”

  • “我们的 Java 代码中使用了 Retrolambda,因为类型缺失,很难转到 Kotlin。”

  • “另一个团队不喜欢 Kotlin,我们也预料不到会这样。”

  • “这不是我们决定的,我们是按照公司的规则来的。”


Java 依旧是编程语言排行榜上的第一名。但 Java 是最好的语言么?不是,因为在每个领域都有更合适的编程语言。


那么,Java 语言到底有什么优势可以占据排行榜第一的位置呢?


  • 其一,语法比较简单,学过计算机编程的开发者都能快速上手。

  • 其二,在若干了领域都有很强的竞争力,比如服务端编程,高性能网络程序,企业软件事务处理,分布式计算,Android 移动终端应用开发等等。

  • 最重要的一点是符合工程学的需求,成为企业软件公司的首选,也受到互联网公司的青睐。


综合而言,Java 语言全能方面是最好的。但同样可以看到,Android 社区拥抱 Kotlin 的速度越来越快,也许有一天,在 Android 世界里,我们会看到 Kotlin 对 Java 的超越。


为什么谷歌会支持 Kotlin?

免责声明:以下内容纯属基于既有事实合理推测,毫无任何实锤。


还记得谷歌与 Oracle 旷日持久的 Java 侵权案吗?这个持续时间长达 8、9 年的纷争目前以谷歌败诉为最新结局,其需要向 Oracle 赔偿 88 亿美元。(编者注:在过去几年时间里,几次裁决分别判两家公司胜诉或败诉。今年 1 月份,谷歌不服判决上诉美国最高法院做最终裁决。)


事件的起因是在 2010 年,作为 Java 拥有者的 Oracle 认为,谷歌在 Android 系统上无偿使用了 37 个 Java APIs,这侵犯了他们的专利,而在 Android 中还有 9 行代码抄袭了 Java,这侵犯了他们的版权。


那 9 行代码造成抄袭的缘由据说是因为当时谷歌的一位工程师在为 Android 项目工作的同时,又为 Sun 公司的 OpenJDK 效力,后来,该工程师直接从 OpenJDK 中复制了 9 行代码到 Android 中,由于 Google 没有得到 Sun 公司的授权,所以 Oracle 收购 Sun 之后,Java 易主,这就相当于侵犯了 Oracle 的版权。


而对于那 37 个 Java APIs,双方各执己见,谷歌认为 API 不应受版权保护,而 Oracle 则认为 谷歌对其的使用具有很强的商业性,再加上用 Java 写的 Android 代码无法在 JVM 上运行,这对 Java 语言是一种分裂,同时 Oracle 认为,Android 通过不当使用 Java API 挤占了 Java ME 可能的市场,这是它巨额索赔的根基。


2016 年初,Google 发言人表示,Android N(7.0) 不再沿用现有的 Java APIs 内容,而是迁移至基于 OpenJDK 的方法,为开发者创建一个通用代码库。虽然没法规避 Java APIs 官司,但至少可以减少潜在的可能纠纷。


到了 2017 年的 Google I/O 大会,Google 宣布 Kotlin 成为 Android 开发的一级语言,可以说对 Kotlin 寄予了厚望。此后,Kotlin 也被开发者视为 Java 的替代品。


在之后的一年时间里,Google 可以说把 Kotlin 当亲儿子看待,为什么这么说呢?让我们来梳理这一年 Google 为 Kotlin 做了什么:


  • 2017 年 11 月,Android Studio 3.0 正式开放下载,此版本的 Android Studio 将 Kotlin 语言支持集成到 IDE 中,在此版本上,代码自动完成和语法突出显示都可以在此版本上平稳运行,今年 4 月推出的 Android Studio 3.1 为 Kotlin 代码提供了更好的 Lint 支持,并通过为 Android Emulator 添加 Quick Boot 功能加快了测试速度。

  • 2018 年 2 月,Google 推出预览版本的 Android KTX,Android KTX 是一组扩展程序,它在 Android 框架和支持库上提供了一个良好的 API 层,使 Kotlin 代码更加简洁。

  • 在 Google I/O 2018 上,Google 发布了 Android Jetpack,它是下一代的 Android 组件,它将支持库向后兼容和立即更新的优点融合到更多组件中,提高开发速率和质量,不仅如此,Android Jetpack 将全面兼容 Kotlin,而且它还能利用 Android KTX 使得 Kotlin 代码更加简洁。


这些都是 Google 逐渐向 Kotlin 靠拢的证据,虽然还不至于让 Kotlin 完全取代 Java,但不难看出 Google 的“偏心”。事实上,Kotlin 自己也非常争气:2017 年 11 月,在第一届 Kotlin 专题大会 KotlinConf 上,Kotlin 首席设计师 Andrey Breslav 宣布 Kotlin 将支持 iOS 开发和 Web 开发,这意味着 Kotlin 向全平台开发迈出了重要的一步。


Kotlin 目前正处于发展的初始阶段,还有很多成长的空间。Google 现在是把它当成 Android 黄昏时期的救命稻草,它能与 Java 100% 互通,但它存在的目的并不是为了取代 Java,只是为了让开发者有多种选择。虽说编程语言只是软件实现的一种工具,开发者无论选择哪种语言都没有绝对的对与错。但在互联网时代,开发者应该懂得审时度势,拥抱变化,才能走得更远。


2019 年 5 月 08 日 16:40258904
用户头像
小智 前 InfoQ 主编

发布了 400 篇内容, 共 318.7 次阅读, 收获喜欢 1762 次。

关注

评论 23 条评论

发布
用户头像
1
2021 年 01 月 28 日 17:49
回复
该评论已删除
2021 年 01 月 28 日 17:49
回复
该评论已删除
2021 年 01 月 29 日 09:49
回复
该评论已删除
2021 年 01 月 29 日 09:49
回复
用户头像
Kotlin真香,用了就回不去了,服务端也开始用了
2020 年 12 月 24 日 09:51
回复
用户头像
为什么现在2020年5月27日,在首页热点7天,出现的是2019 年 5 月 8 日文章,看的我一愣一愣的。
2020 年 05 月 27 日 08:24
回复
因为搜索引擎把读者引来了……
2020 年 05 月 27 日 10:59
回复
这篇文章在热榜上已经挂了快一年了,一直保持坚挺的流量,没下来过……
2020 年 05 月 29 日 09:44
回复
hahaha,原来如此,我还以为是默认infoQ推的新闻,心里想着这新闻也太过时了吧。
2020 年 05 月 29 日 11:20
回复
查看更多回复
用户头像
留下一个足迹
2019 年 12 月 29 日 18:07
回复
用户头像
可以开始学习Kontlin了,但是我觉得如果使用在项目上,还是要等等,稳定后才能用。
2019 年 12 月 26 日 19:22
回复
用户头像
新手,进来报个到。这文章标题清新,内容悲哀。我这十几年用Java没做出来什么。又换吗?
2019 年 12 月 26 日 16:06
回复
用户头像
37个API价值80亿,一个API=2亿+。
2019 年 12 月 02 日 09:13
回复
+9行代码
2020 年 04 月 14 日 14:18
回复
用户头像
Oracle真是一棵毒瘤
2019 年 10 月 11 日 23:53
回复
人家是靠版权费赚钱的。
2020 年 02 月 08 日 12:04
回复
主要是谷歌已经很大影响甲骨文的移动开发市场
2020 年 09 月 02 日 08:07
回复
用户头像
1、巨头们都需要完成对技术的主导和把控,Android也一样,所以google为了绕过oracle搞出来一个Kotlin,既然数据显示1/4的Android尝鲜者在使用kotlin后,又返回到之前的语言,这足以说明问题和接受程度有多严重。
2、强调一点,google是推荐作为Android的开发语言,千万不要拿kotlin作为web开发的语言,这是引入了一个致命性风险,你会发现将kotlin作为web系统的主开发语言将对公司未来的技术团队发展造成灾难,尤其是当沉淀了相当的业务代码基于kotlin实现后,再想返回java除了推倒重来别无他法,而后面加入的web开发同学经过证明发现没有一个能迅速入手或者真心愿意学这门语言,招不到人项目又需要重构时,那时便是灾难的开始。
2019 年 05 月 09 日 16:11
回复
首先不是有1/4尝鲜者返回到java,而是居然有3/4的人用了kotlin就回不去了,证明了kotlin是真的香。我自己Android和java后端经验都有,也都用kotlin做过开发。kotlin的很多特性解决了针对ui这种异步、基于事件的调用和模型,再加上和java兼容性不错、语法糖也多,确实减少了大量模板代码。

而后端其实也比java写起来要轻松很多,既不像groovy那样过于灵活,也不像scala那样和java兼容性过差有过多的编程范式导致学习困难。但java从9开始迭代加快,更多的功能被加入java中。而且google是逼你学(像最开始从eclipse转到android studdio(IntelliJ idea)和gradle),你花九牛二虎学完觉得真香。但后端就没人在乎,你现在用java1.5反正客户也不知道不关心,没有学习动力。在其他领域kotlin还真的难(但我谨慎看好)。
展开
2019 年 05 月 13 日 14:35
回复
我在后端用kotlin,真香。
2019 年 05 月 14 日 11:25
回复
代码写得烂换什么语言都没用.
否定你自己就好,不要否定这个世界,
2019 年 05 月 16 日 08:52
回复
查看更多回复
没有更多了
发现更多内容

架构师训练营第五周感悟

张锐

架构师训练营-第三周-总结

A Matt

极客大学架构师训练营

第五周作业

qqq

极客大学架构师训练营

Week5

架构师训练营-第五周-作业

狂奔嘀兔纸

极客大学架构师训练营

架构师训练营-week5-学习总结

晓-Michelle

极客大学架构师训练营

第五周总结--一致性hash

互金从业者X

事件驱动架构(W5总结)

麻辣

week05 作业

Geek_196d0f

架构师训练营 W5 学习总结

Kun

极客大学架构师训练营

第05周 技术选型-01 命题作业

Jaye

一致性哈希算法与实现

俊俊哥

缓存 算法 一致性哈希

架构师0期05周总结

我在终点等你

第五周总结

qqq

架构师训练营-第五周-课程总结

狂奔嘀兔纸

极客大学架构师训练营

架构师训练营 第五周 作业

一雄

极客大学架构师训练营 作业 第五周

架构师0期05周作业

我在终点等你

架构师训练营第五周作业

张锐

week5作业

架构师训练营 - 作业 - 第五周

心在飞

极客大学架构师训练营

第五周-学习总结

molly

极客大学架构师训练营

架构师训练营第5周作业

养乐多

Week05总结

张磊

架构训练营第五周作业

子豪sirius

「架构师训练营」作业:第 5 周 一致性 hash 算法

Amy

极客大学架构师训练营 作业 一致性hash 一致性Hash算法 第五周

架构师训练营 week5

devfan

一致性hash算法的实现

互金从业者X

架构师训练营-作业3

A Matt

《架构师训练营》第五周总结

Golang实现一致性哈希(consistent hash)

张磊

架构师训练营第五周心得

努力努力再努力m

极客大学架构师训练营

2021 ThoughtWorks 技术雷达峰会

2021 ThoughtWorks 技术雷达峰会

Java失宠,谷歌宣布Kotlin现在是Android开发的首选语言-InfoQ