nashorn 性能
在Oracle应用程序中将Oracle Nashorn用作命令行工具和嵌入式解释器的方案
在Java SE 7之前,JDK附带了基于Mozilla RhinoJavaScript脚本引擎。 Java SE 8将附带一个名为Oracle Nashorn的新引擎,该引擎基于JSR 292和invokedynamic 。 通过invokedynamic绑定的调用站点,它可以更好地符合ECMA规范化JavaScript规范,并提供更好的运行时性能。
本文是对以多种方式使用Oracle Nashorn的介绍。 它涵盖了通过jjs命令行工具使用独立引擎以及将Oracle Nashorn用作Java应用程序内部的嵌入式脚本引擎。 它显示了Java到JavaScript的互操作性,以及如何从JavaScript实现和扩展Java类型,从而提供了两种语言之间的无缝集成。
可以使用最新的JDK 8早期访问版本运行示例。 您还可以使用OpenJDK 8的自定义版本 。 由于有了新的OpenJDK构建基础结构 ,因此此操作非常简单(例如,在安装了XCode命令行工具的Mac OS X操作系统上sh配置&&制作映像 )。
这只是JavaScript
Oracle Nashorn入门的一种简单方法是从命令行运行JavaScript程序。 为此,Oracle JDK或OpenJDK的构建都包含一个名为jjs的命令行工具。 可以在JDK安装的bin /文件夹中找到它,以及著名的java , javac或jar工具。
jjs工具接受JavaScript源代码文件列表作为参数。 考虑以下hello.js文件:
var hello = function() {
print("Hello Nashorn!");
};
hello();
评估就这么简单:
$ jjs hello.js
Hello Nashorn!
$
var data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
var filtered = data .filter( function (i) {
return i % 2 == 0;
});
print(filtered);
var sumOfFiltered = filtered.reduce( function (acc, next) {
return acc + next;
}, 0);
print(sumOfFiltered);
清单1
Oracle Nashorn是该语言的ECMA兼容实现。 因此,我们可以运行更精细的代码段,如清单1所示,它打印出一个过滤后的列表,其中原始列表中仅保留偶数。 它还打印这些偶数的和:
2,4,6,8,10
30
尽管Oracle Nashorn运行符合ECMAJavaScript,但必须注意,通常无法在Web浏览器中访问的对象不可用,例如console , window等。
脚本扩展
如果运行jjs -help以获得jjs命令行工具命令的完整列表,您将注意到一些有趣的功能:
它可以将脚本作为JavaFX应用程序运行。
可以激活JavaScript严格模式。
可以为Java虚拟机(JVM)指定其他类路径元素。
可以启用有趣的脚本模式 。
如果您打算利用jjs来运行用JavaScript编写的系统脚本(就像在Python,Ruby或Bash中一样),则脚本模式很有趣。 脚本模式主要由两种语言扩展组成: heredocs和shell调用 。
Oracle Nashorn入门的一种简单方法是从命令行运行JavaScript程序。
Heredocs。 Heredocs只是多行字符串,它们使用Bash,Perl和Ruby程序员熟悉的语法(请参见清单2)。 文本以<<开头,后跟一个特殊的终止标记,在我们的例子中是EOF 。 格式化将保持不变,直到终止标记。 另外,JavaScript表达式可以嵌入$ {...}表达式中。 运行该程序将产生清单3所示的输出。
var data = {
foo: “bar”,
time: new Date ()
};
print(<So... foo = ${ data .foo} and the current time is ${ data .time} EOF);
清单2
$ jjs -scripting heredocs.js
So...
foo = bar
and the current time is
Thu Aug 01 2013 16:21:16 GMT+0200 (CEST)
$
清单3
请注意,在脚本模式下,双引号字符串可以嵌入将要求值的表达式: “ Hello $ {name}”将根据name的值求值,而“ Hello $ {name}”则不会。
Shell调用。 Shell调用允许调用在反引号字符之间放置命令的外部程序。 考虑以下示例:
var lines =
'ls -lsa'.split("n");
for each (var line in lines) {
print("|> " + line);
}
它运行ls -lsa命令。 shell调用以字符串形式返回标准控制台输出,这使我们能够分割行并打印以“ |>”开头的行,如清单4所示。如果需要对调用的进程进行更详细的控制,则应该知道$ EXEC函数存在,它提供对标准输入,输出和错误流的访问。
jjs -scripting dir.js
|> total 72
|> 0 drwxr-xr-x 2 jponge staff 238 Aug 1 16:12 .
|> 0 drwxr-xr-x 5 jponge staff 170 Aug 1 12:15 ..
|> 8 -rw-r--r-- 1 jponge staff 90 Jul 31 23:36 dir.js
|> 8 -rw-r--r-- 1 jponge staff 304 Aug 1 15:56 hello.js
|> 8 -rw-r--r-- 1 jponge staff 143 Aug 1 16:12 heredocs.js
|>
$
清单4
其他东西。 脚本模式提供了更多好处:
$ ENV变量提供了shell环境变量。
$ ARG变量是程序命令行参数的数组。