java常见log日志如何使用

前言

log日志可以debug错误或者在关键位置输出想要的结果

java日志使用一般有原生logger、log4j、Slf4j等

一般的日志级别都有如下(不同日志不一样的方法参数,注意甄别)

参数 描述
OFF、ON 不输出或者输出所有级别信息,通常使用在setLevel方法中
FATAL 致命错误
ERROR 错误error
WARN 告警信息
INFO info信息
DEBUG 调试信息
TRACE 运行轨迹信息
CONFIG 设定配置信息
FINE 级别轻微信息
FINER 级别更轻微信息
FINEST 级别最轻微信息

1. Java.util.Logger

科普一下原生日志生成工具,主要引用import java.util.logging.Logger;

源代码函数大致有如下方法:
(给定消息将被转发到所有注册的输出处理程序对象)

// 严重信息public void severe(String msg) { log(Level.SEVERE, msg);}// 警告信息public void warning(String msg) { log(Level.WARNING, msg);}// info信息 public void info(String msg) {log(Level.INFO, msg);}// 设定配置信息public void config(String msg) {log(Level.CONFIG, msg);}// 级别小信息public void fine(String msg) {log(Level.FINE, msg);}// 级别更小信息public void finer(String msg) {log(Level.FINE, msg);}// 级别最小信息public void finest(String msg) {log(Level.FINE, msg);}

具体示例如下:

package com.gaokaoli.logger;import java.util.logging.Logger;public class text1 {    public static void main(String []args){        Logger logger = Logger.getLogger("text1");        logger.severe("严重信息");        logger.warning("警示信息");        logger.info("info信息");        logger.config("设定配置信息");        logger.fine("级别小的信息");        logger.finer("级别更小的信息");        logger.finest("级别最小的信息");    }}

输出截图如下:

java常见log日志如何使用

可以看到小于info级别的信息不会在终端上显示输出

通过logger.setLevel(Level.ALL);来控制输出的级别。
ALL则输出severe、warning以及info,OF不输出,如果设置WARNING,则只输出severe以及warning;同理可推其他设置;

java常见log日志如何使用

方法中也有通过调用提供的供应商函数来构造消息,并将其转发到所有注册的输出处理程序对象。

// 严重信息public void severe(Supplier<String> msgSupplier) {log(Level.SEVERE, msgSupplier);}// 警告信息public void warning(Supplier<String> msgSupplier) {log(Level.WARNING, msgSupplier);}// info信息 public void info(Supplier<String> msgSupplier) {log(Level.INFO, msgSupplier); }// 设定配置信息public void config(Supplier<String> msgSupplier) {log(Level.CONFIG, msgSupplier);}// 级别小信息public void fine(Supplier<String> msgSupplier) {log(Level.FINE, msgSupplier);}// 级别更小信息public void finer(Supplier<String> msgSupplier) {log(Level.FINER, msgSupplier);}// 级别最小信息public void finest(Supplier<String> msgSupplier) {log(Level.FINEST, msgSupplier);}

2. org.apache.logging.log4j

在xml文件中导入依赖包

<dependency>       <groupId>org.apache.logging.log4j</groupId>       <artifactId>log4j-api</artifactId>       <version>2.14.1</version></dependency><dependency>       <groupId>org.apache.logging.log4j</groupId>       <artifactId>log4j-core</artifactId>       <version>2.14.1</version></dependency>

示例代码如下:

package com.gaokaoli.logger;import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;public class test3 {    public static void main(String []args){        Logger logger = LogManager.getLogger("text3");        logger.fatal("fatal错误");        logger.error("error错误");        logger.warn("warn警示");        logger.info("info基本信息");        logger.debug("debug调试");        logger.trace("trace 信息");    }}

输出结果如下:

java常见log日志如何使用

其方法大致都有如下:

java常见log日志如何使用

具体使用什么方法可对应查看

3. org.slf4j.Logger

目前主流的日志框架,可以使用占位符进行参数占位

主要通过slf4j作为日志输出
在每个类的开头都加入如下:

在xml文件中引入依赖包

<dependency>	<groupId>org.slf4j</groupId>	<artifactId>slf4j-simple</artifactId>	<version>1.7.25</version>	<scope>compile</scope></dependency>

如果不引入或者引入错误
会出现如下问题:出现SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder“.的解决方法

代码中通过引用通过

import org.slf4j.Logger;import org.slf4j.LoggerFactory;

具体示例代码如下:

import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class text2 {    public static final Logger logger = LoggerFactory.getLogger(text2.class);    public static void main(String []args){        logger.error("error错误");        logger.warn("warn警示");        logger.info("info基本信息");        logger.debug("debug调试");        logger.trace("trace信息");    }}

截图如下:

java常见log日志如何使用

通过输出结果可看到
LoggerFactory.getLogger输出的结果带有类的相对路径,便于开发

以上就是“java常见log日志如何使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

文章标题:java常见log日志如何使用,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/26456

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云
上一篇 2022年9月18日 下午10:25
下一篇 2022年9月18日 下午10:26

相关推荐

  • 企业费用管理神器:9款费控系统精选

    本文介绍了9款费控系统:合思、金蝶云之家、明道云、管家婆、用友U8、AIrbase、Yokoy、SAP Concur、Expensify。 在企业管理中,传统的费用控制不仅费时费力,还容易出错,最终影响企业的财务健康和运营效率,而费控系统是一种有效的解决方案,可以优化费用管理流程,提升整体工作效率。…

    2024年7月23日
    900
  • 数据库权限关系图表是什么

    数据库权限关系图表是一种以图表形式展示数据库权限分配和管理的工具。它可以有效地帮助我们理解和管理数据库中的各种权限关系。数据库权限关系图表主要包含以下几个部分:数据对象、用户(或用户组)、权限类型、权限级别、权限状态等。其中,数据对象是权限关系图表中的核心元素,它代表了数据库中的各种数据资源,如表、…

    2024年7月22日
    100
  • 诚信数据库是什么意思

    诚信数据库是一种收集、存储和管理个人或组织诚信信息的系统。它是一种用于评估和管理个人或组织行为的工具,通常由政府、商业组织或者非营利组织进行运营。诚信数据库的主要功能包括:1、评估个人或组织的诚信状况;2、提供决策支持;3、预防和控制风险;4、促进社会信用体系建设。 在这四大功能中,评估个人或组织的…

    2024年7月22日
    000
  • 数据库期末关系代数是什么

    关系代数是一种对关系进行操作的代数系统,是关系模型的数学基础,主要用于从关系数据库中检索数据。其操作包括选择、投影、并集、差集、笛卡尔积、连接、除法等。其中,选择操作是对关系中的元组进行筛选,只保留满足某一条件的元组;投影操作则是从关系中选择出一部分属性构造一个新的关系。 一、选择操作 选择操作是关…

    2024年7月22日
    500
  • mysql建立数据库用什么命令

    在MySQL中,我们使用"CREATE DATABASE"命令来创建数据库。这是一个非常简单且基础的命令,其语法为:CREATE DATABASE 数据库名。在这个命令中,“CREATE DATABASE”是固定的,而“数据库名”则是你要创建的数据库的名称,可以自己设定。例如,如…

    2024年7月22日
    100
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部