BiConsumer接口源码理解

35 篇文章 0 订阅
34 篇文章 0 订阅


前言

本文章帮助大家对BiConsumer接口的理解。


一、概述

BiConsumer意为二元消费者。顾名思义,它对传入参数进行处理(“消费”),一般为带副作用的处理。它是Consumer接口的两个参数的一个“特例化”。参考Consumer接口。

它是一个函数式接口,它可作为一个两个个参数的无结果lambda表达式的接口类型。

二、源码理解

package java.util.function;
import java.util.function.BiConsumer;

使用BiConsumer接口时,需引入此包。

BiConsumer接口

public interface BiConsumer<T, U> { /*...*/ }

使用接口时传入泛型TU,函数式的参数类型,表示要处理的参数的类型。

BiConsumer方法

accept

void accept(T t, U u);

传入参数tu,进行处理,即提供函数逻辑。通常可以这样使用:

Map<String, String> map = new HashMap<>();
map.put("A", "a");
map.put("B", "b");
map.put("C", "c");
map.forEach(new BiConsumer<String, String>() {
    @Override
    public void accept(String s, String s2) {
        System.out.println(s + s2);
    }
});

以下为精简写法:

Map<String, String> map = new HashMap<>();
map.put("A", "a");
map.put("B", "b");
map.put("C", "c");
map.forEach((s, s2) -> {
    System.out.println(s + s2);
});

例子中程序最终打印“Aa”、“Bb”、“Cc”。参考Map接口的default void forEach(BiConsumer<? super K, ? super V> action)方法。

andThen

default BiConsumer<T, U> andThen(BiConsumer<? super T, ? super U> after) {
    Objects.requireNonNull(after);
    return (l, r) -> {
        accept(l, r);
        after.accept(l, r);
    };
}

组合此函数式和after函数式的函数逻辑,即返回的函数式先执行此函数式处理逻辑,再执行after函数式处理逻辑。若after为空,则抛出NullPointerException异常,参考Objects.requireNonNull方法。default关键字给出默认实现。

注意:若此函数式出现异常,则after函数式不执行。若此方法过程中出现异常,那么这些异常会交给返回函数式的调用方处理。


总结

新人源码理解,望大家多多指点。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值