英文原文: Looking Forward to Java in 2018
在 2017 年即将结束之际,让我们展望一下 2018 年的 Java 平台。
伴随我们进入 2018 年的是,过去一年在 Java 世界中发生了前所未有的更多变化。其部分原因在于 Java 9 的推出,尽管推后了近一年的时间。
然而,随着时间的推移人们可能会发现,推出 Java 9 版本的意义,远没有随该新版本一并推出的 Java 版本发布周期变更为每六个月一次的意义更为重大。Java 版本发布周期的变更,意味着在 2018 年将会推出两个 Java 新版本,而非一个。
2018 年将推出的第一个新版本称为 Java 10,第二个新版本是 Java 11。虽然这一命名方案与现有命名看上去毫无二致,但是新版本只有经过重大公开辩论并达成最终共识后,才能得以推出。
鉴于新版本的推出将切换到这样一种严格按时间点的节奏,预计这将使每个新版本中发布的 Java 特性,比迄今为止所能看到的范围更为缩减。就 Java 10 而言,这意味着新特征的数量将相当之少。
InfoQ 先前曾报道了 Java 10 中的主要特性。此后,该版本中添加特性的仅是一些细微的(Additional Unicode Extensions)、清理性质的(移除了原生的头部生成工具,提供默认的 CA 根证书)、实验性质的(基于 Java 的 JIT 编译器 Graal),或是当前为利基性质的(对异构内存架构的支持)。
至于 Java 11 中考虑了哪些功能,目前更是云山雾罩。我们只能确认下列几个功能在考虑范围内:
invokedynamic
高级开发人员的平台特性。一旦发布日期临近,该特性列表肯定会被填满。但是值得注意的是,列表中目前尚未提及 Java 值类型。这也许并不出乎意料,因为实现值类型需要对 Java 语言和运行时做重大更改,并对 Java 类型系统(包括泛型)做完全重构。
尽管当前原型已工作,但是距特性交付尚有很长的路要走。当前状态只适用于低级别的平台开发人员,以及那些习惯于使用基于反射(reflective)或 MethodHandle 工具的开发人员。看上去令人不可思议的是,尽管值类型将作为 Java 11 的一部分发布,但是 Oracle 依然尚未对该特性预期于何时发布公开发表任何评论。
但是,如果值类型并未作为 Java 11 的一部分提供,这将会产生连锁反应。包含值类型的首个长期支持(LTS)版本将不会在 2021 年 9 月前发布。
在撰写本文时,我们尚不清楚已在提案中的数据类(data classes)特性是否会出现在 Java 11 中。正如 Java 语言架构师 Brian Goetz 所介绍的:
数据类将用于解决类的表示与 API 合约间存在的复杂间接关系。通过使用数据类,编译器可以填入一些常规类成员。
数据类提案与 Scala 的 Case 类具有一些相似之处。但是 Goetz 明确指出,数据类的设计空间中还存在一些可能的变动,该特性的整体语义含义要比目前我们能看到的更为深入。目前的数据类概念是与同处于开发过程中的模式匹配特性深度关联在一起的。但是,这两个特性可能会在不同的版本中提供。
与上面两个特性都相关的是,未来可能对 Switch 形式做改进。Switch 语句块将可作为表达式或声明使用。
该特性相对较小,有望在 Java 11 中交付,即便数据类或模式匹配特性尚未实现。但目前情况看,该特性仍然是一个 JEP 草案。
最终将于 9 月发布的版本,其特性完成日期是 2018 年 6 月。因此,在 Java 11 的整体形态浮出水面之前,我们必须再等待数月时间。