我遇到了log4j ConsoleAppender
:
如果我像这样初始化它:
ConsoleAppender ca = new ConsoleAppender();
ca.setLayout(new PatternLayout(PatternLayout.TTCC_CONVERSION_PATTERN));
它会出错并中断记录。
错误输出:
log4j:ERROR没有名为[null]的appender的输出流或文件集。
如果我像这样初始化它可以正常工作:
ConsoleAppender ca = new ConsoleAppender(new PatternLayout(PatternLayout.TTCC_CONVERSION_PATTERN));
有没有人遇到过这个问题?我无法在Bugzilla存储库中找到它,但如果它实际上是一个问题,那将是非常明显的!
也许我是looking in the wrong place?
相关代码:
import org.apache.log4j.*;
public class ConsoleAppenderIssue {
private static Logger logger = Logger.getLogger(ConsoleAppenderIssue.class);
public static void main(String [] args) {
ConsoleAppender ca = new ConsoleAppender();
ca.setLayout(new PatternLayout(PatternLayout.TTCC_CONVERSION_PATTERN));
logger.addAppender(ca);
logger.info("log something");
}
}
答案 0 :(得分:16)
如果你为ConsoleAppender look at the source:
,你可以看到为什么会这样 public ConsoleAppender(Layout layout) {
this(layout, SYSTEM_OUT);
}
public ConsoleAppender(Layout layout, String target) {
setLayout(layout);
setTarget(target);
activateOptions();
}
您可以看到ConsoleAppender(Layout)
传递SYSTEM_OUT
作为目标,并且在设置布局和目标后也会调用activateOptions
。
如果您自己使用setLayout
,那么您还需要明确设置目标并致电activateOptions
。