是应该是用 Log 还是 Logger 来定义 Log

我们都知道在当前的情况下使用 slf4j 来定义日志基本上都是标配了。

如果下面的语句:

private static final Logger logger = LoggerFactory.getLogger(Dom4JParserUnitTest.class);

但是有时候,我们还会遇到

Log log = LogFactory.getLog(CLASS.class);

这个语句。

上面 2 个语句有什么不同呢?

解答

最主要的不同是使用的 API 不同,LogFactory 是 commons-logging 的 API。

这个 API 已经有多年没有更新了。

虽然可能还有不少项目,目前还在使用中,但是如果可能的话,还是尽量使用 slf4j 的 API 吧。

如果你想写成:

private static final Logger log= LoggerFactory.getLogger(Dom4JParserUnitTest.class);

这样可以吗?

当然是可以的,只是后面的你的使用就只能用 log 了,这个可能会与 LogFactory 中定义的 log 搞混。

所以很多项目的日志,如果使用了 slf4j 的话,通常都会使用 logger。