1

当我运行这段代码并且调用图非常大时,程序会打印到opt输出的最后一行,并在 处被阻塞readLine,即使什么都没有。有谁知道问题是什么?opt -print-callgraph file将调用图发送到错误流。我尝试执行opt -print-callgraph file 2> callgraph以便可以从文件中读取,但它抱怨位置参数太多。

奇怪的是,代码对于小尺寸的调用图运行良好。

我也尝试过使用ProcessBuilder,但我遇到了同样的问题。

Runtime runtime = Runtime.getRuntime();
Process process = runtime.exec("opt -print-callgraph " + file);
BufferedReader in = new BufferedReader(new InputStreamReader(process.getErrorStream()));
String s = null;
try {
    // Gets stuck at readLine after printing out the last line.
    while ((s = in.readLine()) != null) {
        System.out.println(s);
    }
} catch (Exception e) {
    e.printStackTrace();
} finally {
    in.close();
}
4

1 回答 1

2

您需要在单独的线程中读取两个流,或者将它们合并,以便同时读取它们。否则,如果未使用输出,则进程可能会阻塞。在这种情况下,必须有未消耗的输出stdout阻塞进程,这意味着它不会完成,这意味着它不会关闭stderr,,这意味着读取stderr将阻塞。

于 2014-03-29T22:56:25.503 回答