Java Exception的日志输出

Java Exception的日志输出  最近项目中使用多线程,需要将catch到的Exception与其他日志信息一起输出,否则日志会比较杂乱不太好准确定位。那么JavaException到底有哪些信息呢?    Exception中的方法都是继承Throwable类的方法   一般catch到Exception,我们会直接用e.printStackTrace()方法输出exception的完整堆栈信息。但…

大家好,又见面了,我是你们的朋友全栈君。

    最近项目中使用多线程,需要将catch到的 Exception 与其他日志信息一起输出,否则日志会比较杂乱不太好准确定位。那么Java Exception到底有哪些信息呢?

    Exception 中的方法都是继承 Throwable 类的方法

Java Exception的日志输出 

Java Exception的日志输出

    一般catch到Exception,我们会直接用 e.printStackTrace() 方法输出exception 的完整堆栈信息。但如何取出跟 printStackTrace() 方法相同的输出信息呢?写个例子看一下:

    我这边用 org.slf4j.Logger 来记录日志,pom.xml 中引用

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.6.1</version>
 </dependency>

    log4j.xml 配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

	<appender name="console" class="org.apache.log4j.ConsoleAppender">
		 <layout class="org.apache.log4j.PatternLayout">  
            <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss\} %-5p] [%t] (%c:%L) - %m%n" />  
        </layout>
	</appender>
	
	<root>
		<priority value="info" />
		<appender-ref ref="console" />
	</root>
	
</log4j:configuration>

    示例

public class ExceptionPrintMessageTest {
    public static final Logger log = LoggerFactory.getLogger(ExceptionPrintMessageTest.class);

    public static void main(String[] args) {
        try {
            ExceptionPrintMessageTest.errorMethod();
        } catch (Exception e) {
            log.error("localizaizedMessage : {}", e.getLocalizedMessage());
            log.error("exception message : {}", e.getMessage());
            log.error("exception cause : {}", e.getCause());
            log.error("exception suppressed : {}", e.getSuppressed());
            //异常输出
            log.error("exception toString and track space : {}", "\r\n" + e);
            log.error(ExceptionPrintMessageTest.errorTrackSpace(e));
            log.error("---------------------------------------------");
            e.printStackTrace();
        }
    }

    /**
     * 制造异常的方法
     */
    private static void errorMethod() {
        String str = null;
        System.out.println(str.toString());
    }

    /**
     * 输出异常信息
     * @param e
     * @return
     */
    private static String errorTrackSpace(Exception e) {
        StringBuffer sb = new StringBuffer();
        if (e != null) {
            for (StackTraceElement element : e.getStackTrace()) {
                sb.append("\r\n\t").append(element);
            }
        }
        return sb.length() == 0 ? null : sb.toString();
    }
}

     从结果中来看,exception.toString() 和 exception.getTrackSpace() 方法可以完整的获取到 与printTrackSpace() 方法相同的信息。

Java Exception的日志输出

    这与 printTrackSpace() 方法是一致的

Java Exception的日志输出

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/158624.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月13日 上午6:16
下一篇 2022年7月13日 上午6:16


相关推荐

  • cubieboard2 android,在cubieboard2双卡版上从零构建Android4.2.2系统「建议收藏」

    cubieboard2 android,在cubieboard2双卡版上从零构建Android4.2.2系统「建议收藏」板子买了一段时间,终于有时间可以玩玩了,论坛上找浪费了很多时间。把虚拟机环境搭建起来,编译好镜像就可以直接使用烧写工具烧写到TF卡上了。由于买的是双TF卡插槽,没有nand,所以只能在TF卡上制作镜像了。制作过程参考官方文档,好好总结一下,一来以后自己再做时图懒图方便,二来可以方便后来人。主要可以分为一下几个步骤:一、搭建编译环境可以在XP或win7系统上安装虚拟机,在虚拟机中安装交叉编译工具来编…

    2022年7月22日
    17
  • Adobe Illustrator怎么制作同心圆

    Adobe Illustrator怎么制作同心圆

    2026年3月19日
    2
  • jedispool是什么_redis工具类

    jedispool是什么_redis工具类项目中需要用到缓存减少数据库压力,选择redis作为工具,构建一个jedis池达到实际效果11.JedisPoolCacheUtils<!–https://mvnrepository.com/artifact/redis.clients/jedis引入pom–><dependency><groupId&g…

    2025年9月15日
    9
  • C51单片机LCD1602驱动程序

    C51单片机LCD1602驱动程序C51单片机LCD1602驱动程序LCD1602简介1602的引脚操作时序写操作时序时序参数LCD1602关键性操作一、初始化二、清屏指令二、进入模式设置指令三、显示开关控制指令四、功能设定指令RAM地址映射图LCD1602简介LCD1602字符型液晶(每行显示16个字符,一共可以显示两行)——一种专门用来显示字母、数字、符号的点阵型液晶模块。它由若干个57或者510的点阵字符组成,每个点阵字符位都可以用来显示一个字符,每位之间有一个点距的间隔,每行之间也有间隔,起到了字符间距和行间距的作用,正因为如此

    2022年7月16日
    19
  • 【网络基础】路由表,分组转发算法[通俗易懂]

    【网络基础】路由表,分组转发算法

    2022年1月22日
    68
  • 提取吗

    提取吗打开 http static rayfile com zh cn 输入下例代码即可以下载 018 某 MTV 视频系统 ACC 数据库版 500 元 rardd01b5d4 f596 11e0 9b72 0015c55db73d 完整无错的新乡广告网程序源码 rarb96e144f f596 11e0 98fc 0015c55db73d 测试完整的财经教育培训学校网站源码 rarb

    2026年3月26日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号