打字猴:1.700439618e+09
1700439618
1700439619 engine.eval(new FileReader(“c:/model.js”));
1700439620
1700439621 //是否可调用方法
1700439622
1700439623 if(engine instanceof Invocable){
1700439624
1700439625 Invocable in=(Invocable)engine;
1700439626
1700439627 //执行js中的函数
1700439628
1700439629 Double result=(Double)in.invokeFunction(“formula”,frst, sec);
1700439630
1700439631 System.out.println(“运算结果:”+result.intValue());
1700439632
1700439633 }
1700439634
1700439635 }
1700439636
1700439637 }
1700439638
1700439639 上段代码使用Scanner类接受键盘输入的两个数字,然后调用JavaScript脚本的formula函数计算其结果,注意,除非输入了一个非int数字,否则当前JVM会一直运行,这也是模拟生产系统的在线变更状况。运行结果如下:
1700439640
1700439641 输入参数是:1,2
1700439642
1700439643 运算结果:3
1700439644
1700439645 此时,保持JVM的运行状态,我们修改一下formula函数,代码如下:
1700439646
1700439647 function formula(var1,var2){
1700439648
1700439649 return var1+var2-factor;
1700439650
1700439651 }
1700439652
1700439653 其中,乘号变成了减号,计算公式发生了重大改变。回到JVM中继续输入,运行结果如下。
1700439654
1700439655 输入参数是:1,2
1700439656
1700439657 运算结果:2
1700439658
1700439659 修改Java代码,JVM没有重启,输入参数也没有任何改变,仅仅改变脚本函数即可产生不同的结果。这就是脚本语言对系统设计最有利的地方:可以随时发布而不用重新部署;这也是我们Javaer最喜爱它的地方—即使进行变更,也能提供不间断的业务服务。
1700439660
1700439661 Java 6不仅仅提供了代码级的脚本内置,还提供了一个jrunscript命令工具,它可以在批处理中发挥最大效能,而且不需要通过JVM解释脚本语言,可以直接通过该工具运行脚本。想想看,这是多么大的诱惑力呀!而且这个工具是可以跨操作系统的,脚本移植就更容易了。但是有一点需要注意:该工具是实验性的,在以后的JDK中会不会继续提供就很难说了。
1700439662
1700439663
1700439664
1700439665
1700439666 编写高质量代码:改善Java程序的151个建议 [:1700438084]
1700439667 编写高质量代码:改善Java程序的151个建议 建议17:慎用动态编译
[ 上一页 ]  [ :1.700439618e+09 ]  [ 下一页 ]