登录
首页 >  文章 >  java教程

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

时间:2024-12-12 14:24:37 424浏览 收藏

在文章实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《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> 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,为何看不到内部异常信息?》文章吧,也可关注golang学习网公众号了解相关技术文章。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>