如何在多个类中使用log4j?

我目前正在用Java编写一个大型项目,其中包含许多类,有些类很小,只用很少的方法表示对象。我的主班有一个记录器,它运行良好。我希望所有类只能使用一个记录器(带有一个控制台附加程序)。我试图将对记录器的引用传递给不同的类,但是看起来不正确。此外,有时我在不运行main的情况下在类上运行测试,因此未针对其他类初始化记录器。

我的意思是,如何做到这一点的最佳方法是如何从不同的类登录到一个日志,而各类之间没有硬性依赖关系,并且能够对每个类独立使用日志?

回答:

如果我理解正确,那么您现在的情况是:

public class Main {

public static final Logger LOGGER = Logger.getLogger(Main.class);

}

public class AnotherClass {

public void doSomething() {

Main.LOGGER.debug("value=" + value);

}

}

或者,您将对记录器的引用传递到类的构造函数中。

首先,您可以通过简单地使用传递给Logger.getLogger的相同值来使用一个全局记录器,例如:

public class Main {

private static final Logger LOGGER = Logger.getLogger("GLOBAL");

}

public class AnotherClass {

private final Logger LOGGER = Logger.getLogger("GLOBAL");

public void doSomething() {

LOGGER.debug("value=" + value);

}

}

这使用完全相同的记录器,Logger.getLogger在两个调用中返回相同的对象。您不再在类之间具有依赖关系,这将起作用。

我从评论中收集到的另一件事是,您正在手动配置(使用

BasicConfigurator.configure。大多数情况下,这不是必需的,您应该通过将log4j.properties或log4j.xml添加到类路径中来进行配置。在Eclipse中,可以通过将其添加到src

/(如果使用maven,则将其添加到src / main / resources)中来完成;如果使用的是junit,则将其添加到test

/源目录(或将src / test / resources与maven)。这是配置log4j的长期更好的方法,因为您不必在类之间传递信息。

另外,推荐使用记录器的方法是将类传递给Logger.getLogger()。这样,您可以根据类名称过滤输出,这通常比仅使用一个全局记录器有用得多:

public class Main {

private static final Logger LOGGER = Logger.getLogger(Main.class);

public static final main(String[] args) {

LOGGER.debug("started");

}

}

public class AnotherClass {

private final Logger LOGGER = Logger.getLogger(this.getClass());

public void doSomething() {

LOGGER.debug("value=" + value);

}

}

然后,在log4j.properties中,可以为一个文件配置一个附加程序。

# Set root logger level to DEBUG and its only appender to A1.

log4j.rootLogger=DEBUG, A1

# A1 is set to be a ConsoleAppender.

log4j.appender.A1=org.apache.log4j.ConsoleAppender

# A1 uses PatternLayout.

log4j.appender.A1.layout=org.apache.log4j.PatternLayout

log4j.appender.A1.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n

最后,没有必要将所有记录器声明为静态。仅当您要进行 大量

[*]对象创建时,这才有明显的不同。将记录器声明为非静态字段可让您使用,Logger.getLogger(this.getClass());在这种情况下,将记录器添加到类中将成为单行的剪切和粘贴。此slf4j页包含了有关优缺点的详尽说明。因此,除非您有充分的理由不这样做,否则请使用非静态字段。

Cameron说对了,他说您应该尝试并尽可能使用slf4j,它是一个杀手级功能,可以与它一起使用多个日志记录框架,这是正确的。

[*]我的意思是很多。

以上是 如何在多个类中使用log4j? 的全部内容, 来源链接: utcz.com/qa/400334.html

回到顶部