lambda表达式无法抛出异常

背景:在一个方法中使用了lambda表达式,表达式中需要捕获异常,使用throws关键字发现并不起作用,必须使用trycatch才行

public class BeanUtil {

    public static <T,R> List<R> copyList(List<T> source , Class<R> clazz) throws Exception {
        if(CollectionUtils.isEmpty(source)){
            return null;
        }
        List<R> rList = source.stream().map(s ->{
            R r = null;

                r = clazz.newInstance();
            
            BeanUtils.copyProperties(s,r);
            return r;
        } ).collect(Collectors.toList());
        return rList;
    }
}

如上,虽然在方法copyList上使用了throws Exception但是已经无法通过编译,提示有未处理异常,正确代码如下,使用trycatch

 try {
                r = clazz.newInstance();
            } catch (Exception e) {
                e.printStackTrace();
            }

提问:为何lambda表达式中的异常不能在外部throws,只能内部捕获?

看Stream.map(Function<? super T, ? extends R> mapper)方法,参数为Function实例,源码:

public final <R> Stream<R> map(Function<? super P_OUT, ? extends R> mapper) {
        Objects.requireNonNull(mapper);
        return new StatelessOp<P_OUT, R>(this, StreamShape.REFERENCE,
                                     StreamOpFlag.NOT_SORTED | StreamOpFlag.NOT_DISTINCT) {
            @Override
            Sink<P_OUT> opWrapSink(int flags, Sink<R> sink) {
                return new Sink.ChainedReference<P_OUT, R>(sink) {
                    @Override
                    public void accept(P_OUT u) {
                        downstream.accept(mapper.apply(u));
                    }
                };
            }
        };
    }

最终调用了Function中的apply方法,事实上,我们在map方法中写的s ->{……},其实就是重写apply方法的实现,而抛出异常的语句"r = clazz.newInstance()"就是在apply方法中抛出的,就是说在异常语句和copyList方法之间还存在一个apply方法,而apply方法是不允许向上抛出异常的,所以copyList方法自然不能使用throws抛异常。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Lambda表达式在处理集合元素时,有可能会遇到空指针异常(NullPointerException)的问题。当对一个集合进行stream操作时,如果集合中的元素存在空值,那么在Lambda表达式中使用该元素的属性或方法时就会出空指针异常。 在你提供的代码中,当使用Lambda表达式中的`o.getId()`时,如果`o`的`id`属性为空,会出空指针异常。正常情况下,`list`不为空,最多会出`NumberFormatException`,但在这里出的却是空指针异常。 要解决这个问题,你可以在Lambda表达式中添加空值判断。例如,可以使用`Optional`类来对`o.getId()`进行空值检测,避免出空指针异常。可以使用类似下面的代码来处理: ``` list.stream() .map(o -> Optional.ofNullable(o.getId()).map(Long::valueOf).orElse(null)) .collect(Collectors.toList()); ``` 通过使用`Optional.ofNullable`方法来包装`o.getId()`,如果`o.getId()`为空,就返回`null`,否则将其转换为`Long`类型。这样做可以避免空指针异常的发生,让代码更加健壮。 引用: - lambda表达式中list.stream().map(o -> Long.valueOf(o.getId())).collect(Collectors.toList());报出了NPE,正常情况下list不为空不会发生NPE,最多o.getId()中id为空Long.valueOf(null)为空出NumberFormatException,但是最终却是因为id为空出了NPE。 - 此时为空指针异常NPE,而不是NumberFormatException - 本教程为授权出品教程 本套视频涵盖了 Java8 的新特性:Lambda表达式、强大的 Stream API、全新时间日期 API、...Java8 的新特性使 Java 的运行速度更快、代码更少(Lambda 表达式)、便于并行、最大化减少空指针异常。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [lambda表达式中奇怪的NullPointerException异常](https://blog.csdn.net/loveyour_1314/article/details/121668039)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [通俗易懂的Java8新特性教程(含配套资料)](https://download.csdn.net/download/weixin_26875051/19651829)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值