不要使用e.printStackTrace(),请使用logger记录

文章指出,e.printStackTrace()虽然能显示完整错误信息,但只能在控制台输出,且可能导致内存溢出和应用崩溃。建议使用logger代替,如log.error("系统异常:", e)。并提供了一个工具类方法将异常堆栈信息转换为字符串,以便灵活处理。过多使用e.printStackTrace()可能因生成大量字符串导致字符串池满,进而引发应用锁死。" 112327155,10552642,在线流程图工具ProcessOn:免费且支持协作,"['在线工具', '流程图制作', '协作编辑', '图形设计']

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

通常e.getMessage()并不能获取全部的错误信息,需要用到e.printStackTrace()查看完整错误信息,但是这个方法是void 只能在控制台输出。

介绍两种方法,其实logger已经帮我做了这个事情

一、

log.error("系统异常:",e);
一个直接通过log打印出来,这个方法是最简便的

二、

/**
     * 获取e.printStackTrace() 的具体信息,赋值给String 变量,并返回
     * 
     * @param e
     *            Exception
     * @return e.printStackTrace() 中 的信息
     */
    public static String getStackTraceInfo(Exception e) {
        StringWriter sw = null;
        PrintWriter pw = null;
        try {
            sw = new StringWriter();
            pw = new PrintWriter(sw);
            e.printStackTrace(pw);//将出错的栈信息输出到printWriter中
            pw.flush();
            sw.flush();
            return sw.toString();
        } catch (Exception ex) {
            return "printStackTrace()转换错误";

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值