Java Scripting API 的5个技巧(二)

2014-11-23 23:38:04 · 作者: · 浏览: 1

  try
  {
  ScriptEngine engine =
  new ScriptEngineManager().getEngineByName("java script");
  for (String arg : args)
  {
  Bindings bindings = new SimpleBindings();
  bindings.put("author", new Person("Ted", "Neward", 39));
  bindings.put("title", "5 Things You Didnt Know");
  FileReader fr = new FileReader(arg);
  engine.eva l(fr, bindings);
  }
  }
  catch(IOException ioEx)
  {
  ioEx.printStackTrace();
  }
  catch(ScriptException scrEx)
  {
  scrEx.printStackTrace();
  }
  }
  }
  访问所绑定的对象很简单 ― 所绑定对象的名称是作为全局命名空间引入到脚本的,所以在 Rhino 中使用 Person 很简单,如清单 7 所示:

  清单 7. 是谁撰写了本文
  println("Hello from inside scripting!")
  println("author.firstName = " author.firstName)
  您可以看到,JavaBeans 样式的属性被简化为使用名称直接访问,这就好像它们是字段一样。

  5. 编译频繁使用的脚本
  脚本语言的缺点一直存在于性能方面。其中的原因是,大多数情况下脚本语言是 “即时” 解译的,因而它在执行时会损失一些解析和验证文本的时间和 CPU 周期。运行在 JVM 的许多脚本语言最终会将接收的代码转换为 Java 字节码,至少在脚本被第一次解析和验证时进行转换;在 Java 程序关闭时,这些即时编译的代码会消失。将频繁使用的脚本保持为字节码形式可以帮助提升可观的性能。

  我们可以以一种很自然和有意义的方法使用 Java Scripting API。如果返回的 ScriptEngine 实现了 Compilable 接口,那么这个接口所编译的方法可用于将脚本(以一个 String 或一个 Reader 传递过来的)编译为一个 CompiledScript 实例,然后它可用于在 eva l() 方法中使用不同的绑定重复地处理编译后的代码,如清单 8 所示:

  清单 8. 编译解译后的代码
  import java.io.*;
  import javax.script.*;
  public class App
  {
  public static void main(String[] args)
  {
  try
  {
  ScriptEngine engine =
  new ScriptEngineManager().getEngineByName("java script");
  for (String arg : args)
  {
  Bindings bindings = new SimpleBindings();
  bindings.put("author", new Person("Ted", "Neward", 39));
  bindings.put("title", "5 Things You Didnt Know");
  FileReader fr = new FileReader(arg);
  if (engine instanceof Compilable)
  {
  System.out.println("Compiling....");
  Compilable compEngine = (Compilable)engine;
  CompiledScript cs = compEngine.compile(fr);
  cs.eva l(bindings);
  }
  else
  engine.eva l(fr, bindings);
  }
  }
  catch(IOException ioEx)
  {
  ioEx.printStackTrace();
  }

  catch(ScriptException scrEx)
  {
  scrEx.printStackTrace();
  }
  }
  }
  在大多数情况中,CompiledScript 实例需要存储在一个长时间存储中(例如,