Java调用批处理文件,Runtime.getRuntime().exec参数,示例

来源:互联网 发布:网络剧广告植入 编辑:程序博客网 时间:2024/06/08 12:46
//测试结果:能打开,但是需要关闭文件才能中止程序。//String[] cmd = {"notepad.exe","F:\\long_cennect.txt"};//Process process = Runtime.getRuntime().exec(cmd);//测试结果:能打开文件,并且与程序独立,不关闭文件 程序也继续向下执行。// /E:ON 允许cmd扩展  /c 指之后的都是字符串  测试时把E改成F,执行结果是一样的。Process process = Runtime.getRuntime().exec("cmd /E:ON /c start F:\\long_cennect.txt");//Process process = Runtime.getRuntime().exec("cmd.exe /c start F:\\long_cennect.txt"); 用这句话测试结果和上句话是一样的。InputStreamReader inputStr = new InputStreamReader(process.getInputStream());BufferedReader br = new BufferedReader(inputStr);String temp = "";while((temp = br.readLine())!= null){System.out.println(temp);}process.destroy();br.close();inputStr.close();

还可以设置工作目录,对执行与工作目录相关的批处理文件是有用的。
File dir = new File("E:\\Product");
Process process = Runtime.getRuntime().exec("E:\\Product\\copy.bat",null,dir);


用Java编写应用时,有时需要在程序中调用另一个现成的可执行程序或系统命令,这时可以通过组合使用Java提供的Runtime类和Process类的方法实现。下面是一种比较典型的程序模式:   

...   
Process   process   =   Runtime.getRuntime().exec( ".//p.exe ");   
process.waitfor(   );   
...   
在上面的程序中,第一行的“.//p.exe”是要执行的程序名,Runtime.getRuntime()返回当前应用程序的Runtime对象,该对象的exec()方法指示Java虚拟机创建一个子进程执行指定的可执行程序,并返回与该子进程对应的Process对象实例。通过Process可以控制该子进程的执行或获取该子进程的信息。第二条语句的目的等待子进程完成再往下执行。   
但在windows平台上,如果处理不当,有时并不能得到预期的结果。下面是笔者在实际编程中总结的几种需要注意的情况:   
1、执行DOS的内部命令   
如果要执行一条DOS内部命令,有两种方法。一种方法是把命令解释器包含在exec()的参数中。例如,执行dir命令,在NT上,   可写成exec( "cmd.exe   /c   dir "),在windows   95/98下,可写成“command.exe   /c   dir”,其中参数“/c”表示命令执行后关闭Dos立即关闭窗口。另一种方法是,把内部命令放在一个批命令my_dir.bat文件中,在Java程序中写成exec( "my_dir.bat ")。如果仅仅写成exec( "dir "),Java虚拟机则会报运行时错误。前一种方法要保证程序的可移植性,需要在程序中读取运行的操作系统平台,以调用不同的命令解释器。后一种方法则不需要做更多的处理。   
2、打开一个不可执行的文件   
打开一个不可执行的文件,但该文件存在关联的应用程序,则可以有两种方式。   以打开一个word文档a.doc文件为例,Java中可以有以下两种写法:   
exec( "start   .//a.doc ");   
exec( "   c://Program   Files//Microsoft   Office//office//winword.exe   .//a.doc ");   
显然,前一种方法更为简捷方便。   
3、执行一个有标准输出的DOS可执行程序   
在windows平台上,运行被调用程序的DOS窗口在程序执行完毕后往往并不会自动关闭,从而导致Java应用程序阻塞在waitfor(   )。导致该现象的一个可能的原因是,该可执行程序的标准输出比较多,而运行窗口的标准输出缓冲区不够大。解决的办法是,利用Java提供的Process类提供的方法让Java虚拟机截获被调用程序的DOS运行窗口的标准输出,在waitfor()命令之前读出窗口的标准输出缓冲区中的内容。一段典型的程序如下:   
...   
String   ls_1;   
Process   process   =   Runtime.getRuntime().exec( "cmd   /c   dir   //windows ");   
BufferedReader   bufferedReader   =   new   BufferedReader(   /   
new   InputStreamReader(process.getInputStream());   
while   (   (ls_1=bufferedReader.readLine())   !=   null)   
System.out.println(ls_1);   
     
process.waitfor(   );   
0 0
原创粉丝点击