首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

JDK Logger的运用

2012-10-28 
JDK Logger的使用?JDK Logger的使用Logger 日志记录对象,用于记录日志信息。Handler 用于处理日志信息的输

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 甚至是内存缓冲区。

?

热点排行