基本上,我正在制作一个小程序,它将安装一些软件,然后运行一些基本命令来准备该程序。但是,正在发生的是程序开始安装,然后立即转到以下行(注册,更新等)。当然,在完全安装之前不会发生这种情况,因此我想在运行第二个进程之前找到一种等待第一个进程的方法。例如,
Main.say("Installing...");
Process p1 = Runtime.getRuntime().exec(dir + "setup.exe /SILENT");
//Wait here, I need to finish installing first!
Main.say("Registering...");
Process p2 = Runtime.getRuntime().exec(installDir + "program.exe /register aaaa-bbbb-cccc");
Main.say("Updating...");
Process p4 = Runtime.getRuntime().exec(installDir + "program.exe /update -silent");
答案 0 :(得分:21)
致电Process#waitFor()
。它的Javadoc说:
如果需要,导致当前线程等待,直到此
Process
对象表示的进程终止。
奖励:您获得子流程的退出值。因此,您可以使用代码0
检查它是否已成功退出,或者是否发生错误(非零退出代码)。
答案 1 :(得分:5)
您可以使用Process.waitFor()
方法
并且文档说
如果需要,导致当前线程等待,直到进程 由此Process对象表示已终止。此方法返回 如果子进程已经终止,则立即执行。如果 子进程尚未终止,调用线程将被阻塞 直到子进程退出。
答案 2 :(得分:0)
如果您正在运行返回非常长的响应字符串的系统命令,则stdin缓冲区将填满,并且进程似乎挂起。 sqlldr发生在我身上。如果真是这样,请在进程运行时从stdin中读取。
try {
ProcessBuilder pb = new ProcessBuilder("myCommand");
Process p = pb.start();
BufferedReader stdInput = new BufferedReader(new
InputStreamReader(p.getInputStream()));
BufferedReader stdError = new BufferedReader(new
InputStreamReader(p.getErrorStream()));
StringBuffer response = new StringBuffer();
StringBuffer errorStr = new StringBuffer();
boolean alreadyWaited = false;
while (p.isAlive()) {
try {
if(alreadyWaited) {
// read the output from the command because
//if we don't then the buffers fill up and
//the command stops and doesn't return
String temp;
while ((temp = stdInput.readLine()) != null) {
response.append(temp);
}
String errTemp;
while ((errTemp = stdError.readLine()) != null) {
errorStr.append(errTemp);
}
}
Thread.sleep(1000);
alreadyWaited = true;
} catch (InterruptedException e) {
e.printStackTrace();
}
logger.debug("Response is " + response);
logger.debug("Error is: " + errorStr);
}
} catch (IOException e) {
logger.error("Error running system command", e);
}