java.util.logging jdk日志详解

本文介绍了JDK自带日志系统的实现原理,包括日志记录、格式化及输出过程,并通过示例展示了如何定制日志处理器及过滤器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jdk自带的日志,结构并不复杂,功能也能满足绝大部分功能。日志写入位置是开放的,只要继承了handler都可以接收日志的写入。handler本身依赖于LogRecord对象,该对象代表一个日志。Handler接收到日志对象后调用Logger绑定的Formater将日志格式化为指定格式。
然后将格式化的消息依次写入Handler中。日志对象的字段中有个Leval,是一个枚举,枚举中含有一个int类型值,这个值可以用来代表日志的等级。Logger也绑定一个Level,只有Logger的Level高于日志对象的Level时,日志才不会被拒绝。外部通过一个LoggerManager管理日志。来看看这复杂的类结构

demo如下:

public static void main(String[] args) throws IOException, DataFormatException {
        Logger logger = LogManager.getLogManager().getLogger("global");
        logger.info("test");
        logger.log(Level.INFO, "info");
        Handler handler = new Handler(){

            @Override
            public void publish(LogRecord record) {
                System.out.println(record.getMessage());
                
            }

            @Override
            public void flush() {
                
            }

            @Override
            public void close() throws SecurityException {
                
            }
            
        };
        handler.setLevel(Level.INFO);
        logger.addHandler(handler);
        logger.config("我写入失败");
        logger.info("我写入成功了");
        Filter filter = new Filter(){
            public boolean isLoggable(LogRecord record) {
                return !record.getMessage().contains("不文明");
            }
        };
        logger.setFilter(filter);
        logger.info("不文明语言无法写入");
        logger.info("文明语言可以写入");
        
    }

运行结果:

八月 12, 2017 1:18:27 上午 demo.nio.CrcDemo main
INFO: test
八月 12, 2017 1:18:27 上午 demo.nio.CrcDemo main
INFO: info
八月 12, 2017 1:18:27 上午 demo.nio.CrcDemo main
INFO: 我写入成功了
八月 12, 2017 1:18:27 上午 demo.nio.CrcDemo main
INFO: 文明语言可以写入
我写入成功了
文明语言可以写入

转载于:https://www.cnblogs.com/yangyang12138/p/7348562.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值