1、Consumer,相当于消费者,接收一个参数但是不返回。在stream中的最终运算使用到。
public interface Consumer<T> {
// 消费一个数据
void accept(T var1);
// 链式调用,返回一个组合的Consumer,顺序执行
default Consumer<T> andThen(Consumer<? super T> after) {
Objects.requireNonNull(after);
return (t) -> {
this.accept(t);
after.accept(t);
};
}
}
// accept方法使用,最后输出com www
Consumer<String> consumer = System.out::println;
ImmutableList.of("com","www").forEach(consumer);
// andThen方法使用,多个Consumer形成链式调用,先向list中添加,然后打印
Consumer<List<String>> consumer1 = list -> Collections.addAll(list,"com","www");;
Consumer<List<String>> consumer2 = list -> list.forEach(System.out::println);
consumer1.andThen(consumer2).accept(new ArrayList<>());
补充:IntConsumer、DoubleConsumer、LongConsumer不需要使用泛型
2、Supplier,相当于生产者,生产一个结果返回。stream的generate这类的函数有用到。
public interface Supplier<T> {
// 只有一个get方法,用于生产数据
T get();
}
Supplier<Double> supplier = () -> Math.random();
System.out.println(supplier.get());
3、Predicate,预测,接收一个参数,判断并返回true或者false,经常用做过滤一些东西,比如Stream的filter。因为是true/false,所以有与或非逻辑。
public interface Predicate<T> {
// 判断返回true/false
boolean test(T var1);
// 接收一个Predicate,返回一个合并的Predicate,作用是&&
default Predicate<T> and(Predicate<? super T> other) {
Objects.requireNonNull(other);
return (t) -> {
return this.test(t) && other.test(t);
};
}
// 取反
default Predicate<T> negate() {
return (t) -> {
return !this.test(t);
};
}
// 接收一个Predicate,返回一个合并的Predicate,作用是||
default Predicate<T> or(Predicate<? super T> other) {
Objects.requireNonNull(other);
return (t) -> {
return this.test(t) || other.test(t);
};
}
}
// 用作filter的判断
Predicate<String> predicate = item->item.startsWith("www");
ImmutableList.of("www","xxx","wwwccc","fff").stream().filter(predicate).collect(Collectors.toList());
// 定义两个过滤条件,返回并集。这种需求之前遇到过,现在才知道有这种实现方式
Predicate<String> predicate = item -> item.startsWith("www");
Predicate<String> predicate1 = item -> item.length() == 3;
System.out.println(ImmutableList.of("www", "xxx", "wwwccc", "fff").stream().filter(predicate.or(predicate1)).collect(Collectors.toList()));
4、Function,接收一个参数T,返回一个参数F。stream的map中有用到
// apply
R apply(T var1);
// 合并,可以实现链式调用,先执行参数
default <V> Function<V, R> compose(Function<? super V, ? extends T> before) {
Objects.requireNonNull(before);
return (v) -> {
return this.apply(before.apply(v));
};
}
// 链式调用,先执行调用者
default <V> Function<T, V> andThen(Function<? super R, ? extends V> after) {
Objects.requireNonNull(after);
return (t) -> {
return after.apply(this.apply(t));
};
}
// 返回本身,还是很有用的,可以用Function::identity代替it -> it;
static <T> Function<T, T> identity() {
return (t) -> {
return t;
};
}
// function 在map的用法
Function<String, Integer> function = (str) -> Integer.parseInt(str);
ImmutableList.of("1","2","3").stream().map(function).collect(Collectors.toList());
// funciton 的链式调用,先转成int在+1
Function<String, Integer> function = (str) -> Integer.parseInt(str);
Function<Integer, Integer> function1 = item -> item + 1;
ImmutableList.of("1","2","3").stream().map(function.andThen(function1)).collect(Collectors.toList());
5、BiFunction,这是Function的增强版,Function只能接收一个参数,如果想要接收多个参数,可以使用BiFunction,与之类似的还有BiConsumer
public interface BiFunction<T, U, R> {
R apply(T var1, U var2);
default <V> BiFunction<T, U, V> andThen(Function<? super R, ? extends V> after) {
Objects.requireNonNull(after);
return (t, u) -> {
return after.apply(this.apply(t, u));
};
}
}
BiFunction<Integer, Integer, String> biFunction = (a, b) -> String.valueOf(a + b);
Function<String, String> function = (c) -> "Hello:" + c;
一些方法用stream也可以处理的很好,而且可读性更强
网友评论