Java程序如何完全读取自己的控制台输出?

时间:2017-01-02 18:49:59

标签: java logging

首先,我知道如果你想启动一个进程并从中获取控制台输出,你可以使用例如这段代码:

ProcessBuilder builder = new ProcessBuilder(command);
builder.redirectErrorStream(true);
Process proc;
proc = builder.start();
InputStreamReader isr = new InputStreamReader(proc.getInputStream());
BufferedReader reader = new BufferedReader(isr);
String line;
while ((line = reader.readLine()) != null) {
    System.out.println(line);
}

但是如果我想从当前运行的Java程序获取整个控制台输出呢?是否可以阅读它而不会遗漏任何东西?我确信在控制台中显示文本的程序在某些地方使用System.out.println(),大多数情况下它会使用java.util.logging.Logger的许多实例,也可能在其他地方使用其他方法。

顺便说一下,Logger类最终只是使用System.out打印文本还是使用其他任何特殊方法进行记录?

无论如何,我能以某种方式倾听所有这些吗?

提前致谢

1 个答案:

答案 0 :(得分:0)

这可能不是您问题的完整解决方案。但这是我在某处使用的一种解决方法。

您可以将程序标准输出重定向到文件,从程序本身可以在文件更改时读取该文件。

对于基于控制台的应用程序,您可以使用 -

将控制台输出重定向到文件中
Rails::Generators.invoke 'factory_girl:model', ["Audit"]

program.log文件将使用所有标准输出消息创建,即使程序仍在运行。