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