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
//当前编译器
1700439690
1700439691
JavaCompiler cmp=ToolProvider.getSystemJavaCompiler();
1700439692
1700439693
//Java标准文件管理器
1700439694
1700439695
StandardJavaFileManager fm=cmp.getStandardFileManager(null, null, null);
1700439696
1700439697
//Java文件对象
1700439698
1700439699
JavaFileObject jfo=new StringJavaObject(clsName, sourceStr);
1700439700
1700439701
//编译参数,类似于javac<options>中的options
1700439702
1700439703
List<String>optionsList=new ArrayList<String>();
1700439704
1700439705
//编译文件的存放地方,注意:此处是为Eclipse工具特设的
1700439706
1700439707
optionsList.addAll(Arrays.asList(”-d”,”./bin”));
1700439708
1700439709
//要编译的单元
[
上一页 ]
[ :1.70043966e+09 ]
[
下一页 ]