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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mysql 快速导入数据_MySQL导入数据

    mysql 快速导入数据_MySQL导入数据有时候需要批量插入一批数据到数据库,有很多种办法,这里我用到过三种办法:1、通过Excel直接生成insert语句=CONCATENATE(&amp;amp;quot;insertintoaisee_pingfen_fengcai(id,order_n,department,subject_n,teacher_name)values(‘&amp;amp;quot;,A1,&amp;amp;quot;’,’&amp;amp;quot;,B1,&amp;

    2022年9月21日
    2
  • [C#] 逆袭——自制日刷千题的AC自动机攻克HDU OJ

    [C#] 逆袭——自制日刷千题的AC自动机攻克HDU OJ

    2021年9月4日
    56
  • WINDOWS XP安装SQL2000方法

    一.在SQL服务器的安装盘中找到MSDE这个目录,并且点击setup.exe安装它,过程简单直接下一步就OK了。二.重启系统WINDOWSXP,这下就可以看到SQL服务的图标出现了。三.再拿出SQL服务器版的安装光盘,直接安装客户端工具(最简单的方法就是直接点击光盘根目录下的autorun.exe)根据提示安装,自检过程中知道系统不是SERVER版,会提示只安装客户端工具。四.打开企业管理器

    2022年4月13日
    129
  • python中list与string的转换「建议收藏」

    python中list与string的转换「建议收藏」1.list转string命令:”.join(list)其中,引号中是字符之间的分割符,如“,”,“;”,“\t”等等如:list=[1,2,3,4,5]”.join(list)结果即为:12345′,’.join(list)结果即为:1,2,3,4,5str=[]#有的题目要输出字符串,但是有时候list更好操作,于是可以最后list转st…

    2022年6月13日
    356
  • msf win10漏洞_Kali对Windows2008/7的MS17010漏洞测试(MSF自带模块)

    msf win10漏洞_Kali对Windows2008/7的MS17010漏洞测试(MSF自带模块)Kali-TheVulnerablityofMS17010forWindowsServer2008R20x01说明其实这个MSF自带的exp模块还是挺让人伤脑筋的,因为它支持的OS并不是很多,也就WindowsServer2008和Win7能用一下,比他们版本低的xp/2003以及比他们版本高的8/2012都不可用,但是纯粹对于Win2008/7而言,这个方案还是比较方便…

    2022年5月15日
    58
  • 2020中国人口出生率下降_2020人口出生率

    2020中国人口出生率下降_2020人口出生率最新发布《中国统计年鉴2021》显示,2020年中国全国人口出生率为8.52‰,首次跌破10‰,创下了1978来的新低。同期中国人口自然增长率仅为1.45‰,同样创下1978年以来的历史新低。根据年鉴,2020年相比2019年,中国人口净增204万人,而前一年增量还高达467万,2018年增加了530万人。从现有的情况来看,人口总量增加的动力缺乏,越来越难,出生人口越来越少。发展的趋势,就是越来越接近于出生人口与死亡人口相交叉的边缘。和我之前整理的历年人口以及趋势预测不谋而合:中国历年人

    2025年9月14日
    13

发表回复

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

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