栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

将System.out.println重定向到Log4J,同时保留类名信息

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

将System.out.println重定向到Log4J,同时保留类名信息

我能想到的唯一方法是编写自己的

PrintStream
实现,该实现在调用该
println
方法时创建了堆栈跟踪,以便计算出类名。这将是非常可怕的,但它应该可以工作…概念证明示例代码:

import java.io.*;class TracingPrintStream extends PrintStream {  public TracingPrintStream(PrintStream original) {    super(original);  }  // You'd want to override other methods too, of course.  @Override  public void println(String line) {    StackTraceElement[] stack = Thread.currentThread().getStackTrace();    // Element 0 is getStackTrace    // Element 1 is println    // Element 2 is the caller    StackTraceElement caller = stack[2];    super.println(caller.getClassName() + ": " + line);  }}public class Test {  public static void main(String[] args) throws Exception {    System.setOut(new TracingPrintStream(System.out));    System.out.println("Sample line");  }}

(在您的代码中,您应该使其登录到log4j而不是当然的日志……或者也可以。)



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/496803.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号