Hello! 欢迎来到小浪资源网!



Lambda表达式嵌套try-catch,为何看不到内部异常信息?


Lambda表达式嵌套try-catch,为何看不到内部异常信息?

Lambda 表达式嵌套的 trycatch 中看不到报错信息

一段代码在业务代码1部分抛出了异常,但没有看到错误信息。代码如下:

try {     // 第一个 try-catch     List<Plan> plans = planService.lambdaQuery()             .eq(Plan::getYn, YnEnum.YES.getLabel())             .eq(Plan::getStatus, Plan.Status.DONE.getCode())             .isNotNull(Plan::getPId)             .list();     List<List<Plan>> partition = Lists.partition(plans, 5);     partition.forEach(planList -> {         // 第二个 try-catch         try {             // 业务代码1.....         } catch (Exception exception) {             log.Error("报错信息1:", exception);         }     }); } catch (Exception exception) {     log.error("报错信息2:", exception); }

问题:

为什么没有看到 “报错信息1″?

回答:

以下是可能的原因:

  • 没有看到 “报错信息1” 的原因可能是没有给 log.error() 配置输出。请查看 log.error() 级别的输出配置是否正确。
  • 按照代码逻辑,如果业务代码1部分抛出异常,会被循环内的 try-catch 捕获并输出 “报错信息1″,然后继续执行,不会向外层抛出。因此,”报错信息2” 不会被捕获。
  • 强烈怀疑业务代码1确实抛出了异常,但没有看到 “报错信息1″,请检查 log.error() 级别的输出配置。

相关阅读