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