如何使用ProcessBuilder获取wvdial的输出?

时间:2015-11-18 22:05:37

标签: java ubuntu processbuilder

下面的代码打印执行进程的输出(使用不同的线程进行输出):

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提供输出?

1 个答案:

答案 0 :(得分:1)

也许它会写入stderrprocess.getErrorStream()

大多数UNIX程序都避免将人类的信息消息写入stdout。特别是批量程序。 stdout用于数据输出的程序结果,而不是信息性消息。

您也可以理解退出代码,从而废除输出解析的需要。