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