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

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

在 lambda 表达式嵌套的 try-catch 中看不到报错信息

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

try {    // 第一个 try-catch    List plans = planService.lambdaQuery()            .eq(Plan::getYn, YnEnum.YES.getLabel())            .eq(Plan::getStatus, Plan.Status.DONE.getCode())            .isNotNull(Plan::getPId)            .list();    List<List> 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″?

微信 WeLM 微信 WeLM

WeLM不是一个直接的对话机器人,而是一个补全用户输入信息的生成模型。

微信 WeLM 33 查看详情 微信 WeLM

回答:

以下是可能的原因:

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

以上就是Lambda表达式嵌套try-catch,为何看不到内部异常信息?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/381872.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 11:38:25
下一篇 2025年11月6日 11:42:58

相关推荐

发表回复

登录后才能评论
关注微信