java多进程中waitFor()的作用

    在项目中遇到这样的情况:在项目中引入子进程,发现子进程并没有成功运行完成,看不到输出信息不知道怎么回事。度娘后发现问题在于子进程的标准输出流占满缓冲池导致进程阻塞,需要另开两个进程在waitFor()之前将子进程的标准输出流和错误流从缓冲池中取走。具体原因见http://blog.csdn.net/jimzhai/article/details/7864806

 

    从缓冲池读取子进程标准输出和错误流的线程:

    

public class StreamGobbler extends Thread {

    InputStream is;
    String type;

    public StreamGobbler(InputStream is, String type) {
        this.is = is;
        this.type = type;
    }

    public void run() {
        try {
            InputStreamReader isr = new InputStreamReader(is);
            BufferedReader br = new BufferedReader(isr);
            String line = null;
            while ((line = br.readLine()) != null) {
                if (type.equals("Error")) {
                    System.out.println("Error    :" + line);
                } else {
                    System.out.println("Debug:" + line);
                }
            }
        } catch (IOException ioe) {
            ioe.printStackTrace();
        }
    }
}

    对子进程p,创建两个读取子进程缓冲区输出流和错误流的线程,并在waitFor()之前读取出来:

public class ClearOutputAndErrorStream {

    public void clearProcessOutputstream(Process p) throws InterruptedException {
        //p.getInputStream() : Returns the input stream connected to the normal output of the subprocess. 
        //The stream obtains data piped from the standard output of the process represented by this Process object. 
        StreamGobbler outstream = new StreamGobbler(p.getInputStream(), "Output");
        //p.getErrorStream() : Returns the input stream connected to the error output of the subprocess. 
        //The stream obtains data piped from the error output of the process represented by this Process object. 
        StreamGobbler errorstream = new StreamGobbler(p.getErrorStream(), "Error");
        outstream.start();
        errorstream.start();
        p.waitFor();
    }
}
Process p = Runtime.getRuntime().exec("java -cp ./lib/*;./bin test.TestDemo");
coaes.clearProcessOutputstream(p);

 

转载于:https://www.cnblogs.com/luoyuzhong/p/4908306.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值