下面的代码打印执行进程的输出(使用不同的线程进行输出):
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提供输出
发布于 2015-11-18 22:38:12
也许它会写到stderr?process.getErrorStream()
大多数UNIX程序都避免将人类的信息消息写入stdout。尤其是批处理程序。stdout用于程序结果,用于数据输出,而不是用于信息性消息。
您还可以理解退出代码,从而消除输出解析的需要。
https://stackoverflow.com/questions/33791351
复制相似问题