读书人

JDK Logger的运用

发布时间: 2012-10-28 09:54:44 作者: rapoo

JDK Logger的使用

?

JDK Logger的使用


Logger 日志记录对象,用于记录日志信息。

Handler 用于处理日志信息的输出,包括ConsoleHandler和FileHandler。注意必须关闭,否则可能会产生.lck文件。

LogRecord 含有调用信息、log、等级、样式等。

Formatter 通过formatMessage()组装log,format()组装最后的输出信息格式。

?


Logger是通过StackTraceElement来实现调用信息打印的:

StackTraceElement stack[] = (new Throwable()).getStackTrace(); for (int i = 0; i < stack.length; i++)   {        StackTraceElement ste = stack[i];        System.out.println(i + ": "+ste.getClassName());        System.out.println(i + ": "+ste.getMethodName());        System.out.println(i + ": "+ste.getFileName());        System.out.println(i + ": "+ste.getLineNumber()); } 
?

Logger所对应的属性文件在安装jdk目录下的jre/lib/logging.properties


Level:用于表示日志的级别。JDK 日志框架默认有如下级别 : SEVERE,WARNING,INFO,CONFIG,FINE,FINER,FINEST.


Logger处理流程如下图所示:


JDK Logger的运用

Logger 对象首先会判断日志的级别是否满足输出级别的要求,然后将满足级别要求的日志消息交给所配置的 Handler 对象来处理,如果日志对象配置了一个 Filter 对象。那么 Filter 对象将会对日志信息做一次过滤。 Handler 对象接受到日志消息后,根据其所配置的格式化类 Formatter 来改变日志的格式。根据所配置的 Filter 对象和 Level 对象来再次过滤日志信息,最后输出到该种 Handler 对象所指定的输出位置中,该输出位置可以是控制台,文件,网络 socket 甚至是内存缓冲区。

?

读书人网 >编程

热点推荐