gpt4 book ai didi

java - 将 STDOUT 复制到文件而不停止它在屏幕上显示

转载 作者:搜寻专家 更新时间:2023-11-01 01:03:33 25 4
gpt4 key购买 nike

我正在制作的程序设计为无人值守运行,因此我已将 stdout 和 stderr 流重定向到一个日志文件。虽然这没有任何问题,但我仍在制作和调试软件,我希望它也能显示在屏幕上。这可能吗?

重定向我使用过的流

System.setErr(logWriter);
System.setOut(logWriter);

谢谢。

最佳答案

是的。日志记录框架(即 log4j)是最好的,isDebugMode 在开发环境中很方便但是如果你真的需要“tee”你的标准输出你可以喜欢这样。

import java.io.PrintStream;
import java.io.File;
public class TeeStream extends PrintStream {
PrintStream out;
public TeeStream(PrintStream out1, PrintStream out2) {
super(out1);
this.out = out2;
}
public void write(byte buf[], int off, int len) {
try {
super.write(buf, off, len);
out.write(buf, off, len);
} catch (Exception e) {
}
}
public void flush() {
super.flush();
out.flush();
}
}

http://www.exampledepot.com/egs/java.lang/Redirect.html

// import java.io.FileOutputStream;
String dateString = new SimpleDateFormat("yyyyMMdd").format(new Date());
File logFile = new File("mylogfile_" + dateString +".log");
PrintStream logOut = new PrintStream(new FileOutputStream(logFile, true));

PrintStream teeStdOut = new TeeStream(System.out, logOut);
PrintStream teeStdErr = new TeeStream(System.err, logOut);

System.setOut(teeStdOut);
System.setErr(teeStdErr);

您很快就会发现 LOG.somelevel(msg)System.out.println(msg) 更易于管理。在没有部署调试版本的情况下,当事情运行良好时提高日志级别并在它们运行不正常时降低级别是很好的。

关于java - 将 STDOUT 复制到文件而不停止它在屏幕上显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1356706/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com