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

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值