Windows下Java调用可执行文件代码实例
这篇文章主要介绍了Windows下Java调用可执行文件代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
缘起:
由于没有找到java转换文件的接口,因此使用java调用exe文件进行文件转换
publicvoidconvertFile(){ Runtimern=Runtime.getRuntime(); Processp=null; try{ p=rn.exec("D:/convert/Convert.exeD:/convert/my.ifcD:/convert/tmp.dae"); }catch(Exceptione){ e.printStackTrace(); } }
调用这个方法,就可以实现文件的转换了,和在命令窗口执行的结果一样
获取执行结果
publicvoidconvertFile(){ Runtimern=Runtime.getRuntime(); Processp=null; try{ p=rn.exec("D:/convert/Convert.exeD:/convert/my.ifcD:/convert/tmp.dae");intexitVal=p.waitFor(); if(exitVal==0){ System.out.println("转换成功."); }else{ System.out.println("转换失败."); } }catch(Exceptione){ e.printStackTrace(); }finally{ p.destroy(); } }
注:
安全编码规范中都会指出:使用Process.waitfor的时候,可能导致进程阻塞,甚至死锁
出现挂起的原因为:可执行程序的标准输出比较多,而运行窗口的标准输出缓冲区不够大。
1.主进程中调用Runtime.exec会创建一个子进程,用于执行程序。子进程创建后会和主进程分别独立运行
2.主进程需要等待脚本执行完成,然后对执行程序返回值或输出进行处理,所以这里主进程调用Process.waitfor等待子进程完成
3.子进程执行过程就是不断的打印信息。主进程中可以通过Process.getInputStream和Process.getErrorStream获取并处理
4.子进程不断向主进程发生数据,而主进程调用Process.waitfor后已挂起。当前子进程和主进程之间的缓冲区塞满后,子进程不能继续写数据,然后也会挂起
5.子进程等待主进程读取数据,主进程等待子进程结束,两个进程相互等待,最终导致死锁
解决的办法是,利用Java中Process类提供的方法让Java虚拟机截获被调用程序的DOS运行窗口的标准输出,在waitfor()命令之前读出窗口的标准输出缓冲区中的内容。
优化代码
publicvoidconvertFile(){ Runtimern=Runtime.getRuntime(); Processp=null; try{ p=rn.exec("D:/convert/Convert.exeD:/convert/my.ifcD:/convert/tmp.dae"); InputStreamstdin=p.getInputStream(); InputStreamReaderisr=newInputStreamReader(stdin); BufferedReaderbr=newBufferedReader(isr); Stringline=null; System.out.println(""); intexitVal=p.waitFor(); if(exitVal==0){ System.out.println("转换成功."); }else{ System.out.println("转换失败."); } }catch(Exceptione){ e.printStackTrace(); }finally{ p.destroy(); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。