• java陷阱之无法捕获异常问题


    加载支付配置的config类

    @Slf4j
    public class CenterPayConfig {
        private static Properties conf = null;
        private final static String propertiesFilePath = "/centerpay_v2.properties";
    
        private static CenterPayConfig instance = new CenterPayConfig();
        public static CenterPayConfig newInstance() {
            return instance;
        }
    
        private CenterPayConfig() {
    
        }
        static {
            log.info("开始加载支付中心v2相关配置");
            try {
                conf = new Properties();
                InputStream in = CenterPayConfig.class.getClassLoader().getResourceAsStream(propertiesFilePath);
                conf.load(in);
            }catch(IOException e){
                log.error("加载支付中心v2文件失败",e);
                e.printStackTrace();
            }
        }
    
    }

    使用

    try {
               String  url= CenterPayConfig.newInstance().getUrl();
                ........
            }
            catch (Exception e){
                logger.error("主动查询异常:{}",paymentCode,e);
                jsonResult=new JsonResult(904,"扫码支付异常,请尝试使用app支付或者公众号支付");
            }

    如果抛出非IOException  使用的地方并不能捕获导致,导致异常但是没有异常日志 无法排查  ,所以将IOException 改成Exception

     static {
            log.info("开始加载支付中心v2相关配置");
            try {
                conf = new Properties();
                InputStream in = CenterPayConfig.class.getClassLoader().getResourceAsStream(propertiesFilePath);
                conf.load(in);
            }catch(IOException e){
                log.error("加载支付中心v2文件失败",e);
                e.printStackTrace();
            }catch (Exception e){
                log.error("加载支付中心v2文件异常",e);
                e.printStackTrace();
            }
        }

    记录一下 如果出现自己怀疑有异常又没有捕获的情况 可以考虑 此场景

  • 相关阅读:
    input 去除边框
    分页封装
    python后端继承序列化,不同访问形式返回不同结果
    解决vue前端不显示自定义字段
    Vue 获取后端多对多关联表信息
    vue 前段增删改查代码规范
    前段增删改查的应用
    ant-design-vue基础
    python 后端 数据库的创表及增删改查 简单使用
    配置Uwsgi+Nginx+Django+Vue
  • 原文地址:https://www.cnblogs.com/LQBlog/p/15174684.html
Copyright © 2020-2023  润新知