随着工作的推移,发现什么东西都自己写很辛苦,这时候就开始想着偷懒,网上找各种工具了,但是java中基本的判断循环还是用的最常见的,今天偶然发现开源项目好多都用的lambda表达式,所以静下心来研究一下。
lamdba表达式,()->{}; 如果没有参数可以在()不写,有参数要写,可以不用写参数类型,如果该参数需要被final等修饰符修饰需要加上参数类型。
// 使用 lambda 表达式以及函数操作(functional operation) players.forEach((player) -> System.out.print(player + "; ")); // 在 Java 8 中使用双冒号操作符(double colon operator) players.forEach(System.out::println);
lambda 常见接口:
Predicate接口
输入一个参数,并返回一个
Boolean值,其中内置许多用于逻辑判断的默认方法
Predicate<String> predicate = (s) -> s.length() > 0;
boolean test = predicate.test("test");
判断是否满足上面的条件,满足返回true,不满足返回false
Predicate<Object> pre = Objects::nonNull;
判断对象是否非空,非空返回true,否则返回false
Function接口
接收一个参数,返回单一的结果,默认的方法(andThen)可将多个函数串在一起,形成复合Funtion(有输入,有输出)
结果,
Function<Integer, Integer> name = e -> e * 2;
Function<Integer, Integer> square = e -> e * e;
int value = name.andThen(square).apply(3);
compose 和 andThen 的不同之处是函数执行的顺序不同。compose 函数先执行参数,然后执行调用者,而 andThen 先执行调用者,然后再执行参数。 所以说明andThen 先执行name后执行square
Supplier接口
返回一个给定类型的结果,与Function不同的是,Supplier不需要接受参数(供应者,有输出无输入)
Supplier<String> supplier = () -> "special type value";
String s = supplier.get();
System.out.println(s);
Consumer接口
代表了在单一的输入参数上需要进行的操作。和Function不同的是,Consumer没有返回值(消费者,有输入,无输出)
Consumer<Integer> add5 = (p) -> {
System.out.println("old value:" + p);
p = p + 5;
System.out.println("new value:" + p);
};
add5.accept(10);
Stream的使用过程有着固定的模式:
- 创建Stream
- 通过中间操作,对原始Stream进行“变化”并生成新的Stream
- 使用完结操作,生成最终结果
也就是