BiConsumer<T, U>函数式接口
函数式接口实践
实践一:Comsumer函数式接口
/**
*
* Comsumer函数式接口的测试
*/
@Test
public void testFunction01(){
// 创建字符串对象
StringBuilder sb = new StringBuilder("这是一个字符串, ");
// 声明函数对象 consumer
Consumer<StringBuilder> consumer = (str) -> str.append("测试1");
// 调用Consumer.accept()方法接收参数
consumer.accept(sb);
System.out.println(sb.toString());
}
运行结果:
这是一个字符串, 测试1实践二:BiConsumer函数式接口
/**
*
* BiConsumer函数式接口的测试
*/
@Test
public void testFunction02(){
// 创建字符串对象
StringBuilder sb = new StringBuilder();
// 声明函数对象 consumer
BiConsumer<String,String> consumer = (str1, str2) -> {
// 拼接字符串
sb.append(str1);
sb.append(str2);
};
// 调用Consumer.accept()方法接收参数
consumer.accept("我是参数a,","我是参数b。我们被BiConsumer.accept(T,V)接收并处理了");
System.out.println(sb);
}运行结果:
我是参数a, 我是参数b。我们被BiConsumer.accept(T,V)接收并处理了源码:
package sourcecode.analysis;
import java.util.Objects;
/**
* to operate via side-effects.
* 本函数接口特征:
* 1.输入参数2个.
* 2.无输出结果
* 3.本函数接口和Consumer函数接口唯一区别:
* 4.和其它函数接口不同的是:BiConsumer接口的操作是通过其副作用而完成的.
* 5.本函数接口功能方法:accept(t,u)
*
* @param <T> 第一个操作参数类型
* @param <U> 第二个操作参数类型
*
* @see java.util.function.Consumer
* @since 1.8
*/
@FunctionalInterface
public interface BiConsumer<T, U> {
/**
* 本方法的调用,会对输入参数执行指定的行为
* @param t 第一个输入参数
* @param u 第二个输入参数
*/
void accept(T t, U u);
/**
* andThen方法,会执行两次Consumer接口的accept方法.两次执行顺序上,先对输入参数执行accept()方法;然后
* 再对输入参数执行一次after.accept()方法.(注意:两次均为对输入参数的操作,after操作并不是对第一次accept结果的操作)
* 这两次任何一次accept操作出现问题,都将抛异常到方法调用者处.
* 如果执行accept这一操作出现异常,fater操作将不会执行.
* @return 一个按顺序执行的组合的{BiConsumer} 操作后面跟着{@code after}操作
*/
default BiConsumer<T, U> andThen(BiConsumer<? super T, ? super U> after) {
Objects.requireNonNull(after);
return (l, r) -> {
accept(l, r);
after.accept(l, r);
};
}
}
苏ICP备16040035号-5