jdk1.8 lambda表达式入门

随着工作的推移,发现什么东西都自己写很辛苦,这时候就开始想着偷懒,网上找各种工具了,但是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 predicate = (s) -> s.length() > 0;
boolean test = predicate.test("test");

判断是否满足上面的条件,满足返回true,不满足返回false

Predicate pre = Objects::nonNull; 
  

判断对象是否非空,非空返回true,否则返回false

Function接口

接收一个参数,返回单一的结果,默认的方法(andThen)可将多个函数串在一起,形成复合Funtion(有输入,有输出) 
结果,

Function name = e -> e * 2;

Function square = e -> e * e;

int value = name.andThen(square).apply(3);

compose 和 andThen 的不同之处是函数执行的顺序不同。compose 函数先执行参数,然后执行调用者,而 andThen 先执行调用者,然后再执行参数。 所以说明andThen  先执行name后执行square

 

Supplier接口

返回一个给定类型的结果,与Function不同的是,Supplier不需要接受参数(供应者,有输出无输入)

Supplier supplier = () -> "special type value";
String s = supplier.get();
System.out.println(s);

Consumer接口

代表了在单一的输入参数上需要进行的操作。和Function不同的是,Consumer没有返回值(消费者,有输入,无输出)

Consumer add5 = (p) -> {
    System.out.println("old value:" + p);
    p = p + 5;
    System.out.println("new value:" + p);
};
add5.accept(10);

Stream的使用过程有着固定的模式:

  1. 创建Stream
  2. 通过中间操作,对原始Stream进行“变化”并生成新的Stream
  3. 使用完结操作,生成最终结果 
    也就是

你可能感兴趣的:(JDK)