我有一个在 Windows 7 控制台中运行的 Java 程序:
java -classpath classfolder mypackage.MyProgram
这个程序运行了很长时间。它一次又一次地使用 System.out.println 将输出写入控制台。
是否可以在不修改现有 Java 代码的情况下将其输出实时发送到控制台和日志文件?
如果 Windows 7 无法做到这一点,是否可以用 Java 编写 Tee 实用程序?
它在 Windows 8 中解决了吗?
我有一个在 Windows 7 控制台中运行的 Java 程序:
java -classpath classfolder mypackage.MyProgram
这个程序运行了很长时间。它一次又一次地使用 System.out.println 将输出写入控制台。
是否可以在不修改现有 Java 代码的情况下将其输出实时发送到控制台和日志文件?
如果 Windows 7 无法做到这一点,是否可以用 Java 编写 Tee 实用程序?
它在 Windows 8 中解决了吗?
要做到这一点“不修改现有的 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
有可能,只需从 system.in 读取并输出到 system.out 和文件。