手机版
你好,游客 登录 注册
背景:
阅读新闻

Oracle弃用Nashorn JavaScript引擎

[日期:2018-06-20] 来源:infoq.com  作者:Kesha Williams ,译者 谢丽 [字体: ]

Oracle通过JDK增强提案(JEP)355宣布弃用Nashorn JavaScript引擎,最终将从未来所有的JDK中删除。ECMAScript的语言结构变化太快,Oracle发现,维护Nashorn JavaScript引擎变得非常困难。

Nashorn最初是在JDK 8中引入的,用于取代Rhino脚本引擎。当其发布时,Nashorn是ECMAScript-262 5.1的完整实现,增强了Java和JavaScript的兼容性。最近还增加了新的ECMAScript 6(ES6)特性。借助Nashorn,开发人员可以从JavaScript调用Java代码,也可以从Java代码调用JavaScript函数。Nashorn可以作为Java应用程序的嵌入式解释器,提供使用Nashorn命令行工具jjs从命令行运行JavaScript的能力。当在Java中对JavaScript代码求值时,Nashorn实现了javax.script API。Oracle表示,弃用Nashorn不会影响javax.script API。

移除Nashorn后,有些应用程序可能会因为需要JavaScript而无法运行。

具体要弃用的模块如下:

  • jdk.scripting.nashorn——包含jdk.nashorn.api.scriptingjdk.nashorn.api.tree包;
  • jdk.scripting.nashorn.shell——包含jjs工具;
  • jdk.dynalink——包含Dynalink支持库。

Oracle实验室高级研究总监Thomas Wuerthinger表示,GraalVM是一个不错的替代方案,与Nashorn相比,它的性能更好,与ECMAScript的兼容性也更好。虽然GraalVM现在还没有生产就绪,但Wuerthinger向开发者社区保证,在Nashorn真正弃用之前,基于GraalVM的JavaScript实现将在所有相关平台上实现生产就绪。

在Nashorn真正弃用之前,基于#GraalVM的JavaScript实现将在所有相关平台上实现生产就绪。它将提供更好的性能,并且完全兼容ECMAScript的最新标准。

— Thomas Wuerthinger (@thomaswue) 2018年6月7日

真正要在将来的JDK版本中删除相关的类型和模块,Oracle会提交一份单独的JEP。

开发社区的总体反应是担忧,尤其是那些在业务逻辑中大量使用了Nashorn的。Oracle听上去愿意撤回JEP 335,如果有足够的开发人员反馈的话。

还有一种选择是有一组可信赖的开发人员清楚表达今后维护Nashorn的愿望。如果那种情况在这份JEP完善之前出现,那么它还是可以撤回的。如果那是在这份JEP完善之后,但是在Nashorn被移除之前,则可以再提交一份JEP来逆转这次弃用。

按照Oracle的说法,Nashorn的使用情况很难跟踪,因此,有任何回退都会及时发布通知,而不管JEP 335是否通过。使用Nashorn的开发人员应该向Oracle提供反馈,以便他们可以更好地了解Nashorn的使用情况。

查看英文原文:Oracle Deprecates the Nashorn JavaScript Engine

linux
相关资讯       Nashorn JavaScript引擎 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款