首页 > 代码库 > java.util.logging jdk日志详解
java.util.logging jdk日志详解
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: 文明语言可以写入
我写入成功了
文明语言可以写入
java.util.logging jdk日志详解
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。