黑马程序员技术交流社区

标题: 关于log4j使用的一个问题 [打印本页]

作者: 王晓东    时间: 2012-6-6 15:48
标题: 关于log4j使用的一个问题
在类中使用log4j记录日志,都会在本类中定义了一个日志记录器,如下:
  1. private static final Logger log=Logger.getLogger(Logj4jTest.class);
复制代码
private static final Logger log=Logger.getLogger(Logj4jTest.class);
private static final Logger log2=Logger.getLogger(Logj4jTest2.class);
这两个日志记录器对象引用是不一样的,意味着每个类这样写,创建的日志记录器对象就特别多了。
使用到log4j的类都这样写,而日志的输出目的地都是一样的。

所以我有疑问,为什么不在一个类中获得这么一个日志记录器对象,以后其它类需要日志记录的时候,就从这个类获得日志记录器来记录日志呢?

作者: 张少威    时间: 2012-6-6 15:52
1. 楼主的意思地是建一个静态的log类,以后的类直接调用。省得每次都直接定义了。貌似确实能简单些。
2. 这样增加类之间的耦合。
3. 但是如果某个类的比较特殊,需要一个特别的log,你的代码修改的比较多。不好维护。

希望楼主满意
作者: 王渠    时间: 2012-6-6 15:58
每个 Logger 都跟踪一个“父”Logger,也就是 Logger 名称空间中与其最近的现有祖先。

每个 Logger 都有一个与其相关的 "Level"。这反映了此 logger 所关心的最低 Level。如果将 Logger 的级别设置为 null,那么它的有效级别继承自父 Logger,这可以通过其父 Logger 一直沿树向上递归得到。

这是API上面的原话,是一个树形结构,这样的话方便管理,对于一个项目比较大了,用一个logger来管理也是不现实的





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2