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
1700439667
编写高质量代码:改善Java程序的151个建议 建议17:慎用动态编译
[
上一页 ]
[ :1.700439618e+09 ]
[
下一页 ]