java Exception相关

【写在前面】个人观点,如有错误还望指正。

错误捕获

1,e.getMessage(); 有些异常是无法取到值的,即可能为【null】

 2,e.getStackTrace()[0]往往取不到有利于排错的信息。

3,   logger.error(e);效果等同于e.getMessage();

4,程序未走catch块,且没有异常信息抛出?

try{
       int a = 1/0;
} catch (ParseException e) {
    System.out.println("666666666666666666");
    e.printStackTrace();
}

catch里面的异常类不足以捕获程序中的异常类型,就GG了。

方案】:ParseException 改为Exception

建议捕获

1,直接记录到日志文件: logger.error("exceptionObj",e); 

2,e.printStackTrace 重定向到指定文件。【缺点】:格式很乱 【优点】:存实体类入库

参考

public static void printStackInfoToMap(Map<String,Object> logMap,Exception e){
    PrintWriter printWriter = null;
    Writer writer = null;
    try {
        writer = new StringWriter();
        printWriter = new PrintWriter(writer);
        e.printStackTrace(printWsriter);
        printWriter.flush();
        logMap.put("xxxx",writer.toString());
    } catch (Exception e1) {
        e1.printStackTrace();
    } finally {
        if(printWriter != null){
            printWriter.close();
        }
        if(writer != null){
            try {
                writer.close();
            } catch (IOException e1) {
                e1.printStackTrace();
            }
        }
    }
}

注意】: 日志如需入库

1,设计好索引 

2,  日志数据定期迁移,历史日志定时清理 

3,需要有日志开关控制,控制是否记录日志。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值