在继续Java之前等待进程完成

时间:2013-07-31 13:53:45

标签: java process

基本上,我正在制作一个小程序,它将安装一些软件,然后运行一些基本命令来准备该程序。但是,正在发生的是程序开始安装,然后立即转到以下行(注册,更新等)。当然,在完全安装之前不会发生这种情况,因此我想在运行第二个进程之前找到一种等待第一个进程的方法。例如,

    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");

3 个答案:

答案 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);
    }