4

我有一个在 Windows 7 控制台中运行的 Java 程序:

java -classpath classfolder mypackage.MyProgram

这个程序运行了很长时间。它一次又一次地使用 System.out.println 将输出写入控制台。

是否可以在不修改现有 Java 代码的情况下将其输出实时发送到控制台和日志文件?

如果 Windows 7 无法做到这一点,是否可以用 Java 编写 Tee 实用程序?

它在 Windows 8 中解决了吗?

4

3 回答 3

4

tee命令可以帮助您,但它是一个 Unix 命令。您可以将此批处理文件用作tee.

例子:

systeminfo | tee_nt.bat 1.txt
于 2013-01-11T13:13:56.247 回答
2

要做到这一点“不修改现有的 Java 代码”,您可以编写另一个适当重新分配的包装类,System.out然后调用现有的主类

package mypackage;
import java.io.*;
import org.apache.commons.io.output.*;

public class TeeWrapper {
  public static void main(String[] args) throws Exception {
    FileOutputStream logFile = new FileOutputStream("log.txt");
    try {
      System.setOut(new PrintStream(new TeeOutputStream(System.out, logFile)));
      MyProgram.main(args);
    } finally {
      logFile.close();
    }
  }
}

(使用来自 Apache commons-io 的TeeOutputStream )。

您运行包装器而不是原始类

java -classpath classfolder mypackage.TeeWrapper
于 2013-01-11T12:56:05.557 回答
1

有可能,只需从 system.in 读取并输出到 system.out 和文件。

于 2013-01-11T12:52:16.590 回答