在 lambda 表达式嵌套的 try-catch 中看不到报错信息
一段代码在业务代码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() 级别的输出配置。
以上就是Lambda表达式嵌套try-catch,为何看不到内部异常信息?的详细内容,更多请关注其它相关文章!
Article Links:https://www.hinyin.com/n/258987.html
Article Source:admin
Article Copyright:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。