下面的代码打印执行进程的输出(使用不同的线程进行输出):
public static void main(String[] args) throws InterruptedException,
IOException {
ProcessBuilder builder = new ProcessBuilder("some_command");
final Process process = builder.start();
final Thread ioThread = new Thread() {
@Override
public void run() {
try {
final BufferedReader reader = new BufferedReader(
new InputStreamReader(process.getInputStream()));
String line;
while ((line = reader.readLine()) != null) {
System.out.println(line);
}
reader.close();
} catch (final Exception e) {
e.printStackTrace();
}
}
};
ioThread.start();
process.waitFor();
}
所以,如果我用
运行这段代码ProcessBuilder builder = new ProcessBuilder("ping","8.8.8.8");
输出将是这样的:
PING 8.8.8.8 (8.8.8.8) 56(84) bytes of data.
64 bytes from 8.8.8.8: icmp_seq=1 ttl=57 time=205 ms
64 bytes from 8.8.8.8: icmp_seq=2 ttl=57 time=202 ms
...
但如果我跑
ProcessBuilder builder = new ProcessBuilder("wvdial");
然后执行命令(wvdial将启动)但BufferedReader
中没有输出。终端中的wvdial
显示输出文本。
为什么wvdial
没有为ProcessBuilder
提供输出?
答案 0 :(得分:1)
也许它会写入stderr
? process.getErrorStream()
大多数UNIX程序都避免将人类的信息消息写入stdout
。特别是批量程序。 stdout
用于数据输出的程序结果,而不是信息性消息。
您也可以理解退出代码,从而废除输出解析的需要。