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:慎用动态编译
1700439668
1700439669
动态编译一直是Java的梦想,从Java 6版本它开始支持动态编译了,可以在运行期直接编译.java文件,执行.class,并且能够获得相关的输入输出,甚至还能监听相关的事件。不过,我们最期望的还是给定一段代码,直接编译,然后运行,也就是空中编译执行(on-the-fly),来看如下代码:
1700439670
1700439671
public class Client{
1700439672
1700439673
public static void main(String[]args)throws Exception{
1700439674
1700439675
//Java源代码
1700439676
1700439677
String sourceStr=“public class Hello{public String sayHello(String name)
1700439678
1700439679
{return”Hello,”+name+”!”;}}”;
1700439680
1700439681
//类名及文件名
1700439682
1700439683
String clsName=“Hello”;
1700439684
1700439685
//方法名
1700439686
1700439687
String methodName=“sayHello”;
1700439688
1700439689
//当前编译器
[
上一页 ]
[ :1.70043964e+09 ]
[
下一页 ]