Process p = Runtime.getRuntime().exec("mybashscript.sh");
(new StreamGobblerThread(p.getInputStream())).start();
(new StreamGobblerThread(p.getErrorStream())).start();
p.waitFor();
returnValue = p.exitValue();
StreamGobblerThread仅有一个run()方法,该方法可以
while(((inputStream.available>0) { inputStream.skip(available); }
大约有20%的时间可以工作,但是大多数情况下脚本会立即失败,返回码为141.
从我在Google上找到的信息来看,141是收到SIGPIPE时的返回码.
有任何想法吗?
解决方法:
我不是100%知道是什么问题,但首先:
while(((inputStream.available>0) { inputStream.skip(available); }
无效.
这是因为inputStream.available()不会阻塞,因此,如果它没有立即读取的任何内容,则根本不会读取任何内容.
您最好拥有这样的东西:
byte[] buf = new byte[8192];
int next;
try {
while ((next = in.read(buf)) != -1) {}
} catch (IOException e) {
throw new GroovyRuntimeException("exception while dumping process stream", e);
}
read()处于阻塞状态,因此它实际上将继续读取,直到正确关闭流为止.
(注意:此代码来自Groovy的consumptProcessOutput()实现.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。