lambda表达式需要支持函数式接口(接口中只有一个抽象方法的接口),可以用@FunctionalInterface注解修饰接口,这样如果定义超过一个抽象方法就会报错
几种格式:
格式一:无参数,无返回值
()->System.out.println("Hello ");
格式二:有一个参数,无返回值
(x)->System.out.println("Hello ");
格式三:若只有一个参数,小括号可以省略不写
x->System.out.println("Hello ");
格式四:两个以上的参数,有返回值,并且Lambda体中有多条语句
Compare<Integer> com =(x,y)->{
System.out.println("Hello ");
return Interger.compare(x,y);
}
格式五:若Lambda中只有一条语句,return和大括号都可以省略不写
Compare<Integer> com =(x,y)-> Interger.compare(x,y);
lambda优势对比:
方法A:
public boolean includeAccount(String side) { boolean hasAccount = false; Pair[] pairs = pairs(); if (pairs.length == 0) { return hasAccount; } else { for (Pair pair : pairs) { if (pair.from.equals(side)) { hasAccount =true; } else if (pair.to.equals(side)) { hasAccount =true; } } } return hasAccount; }
方法B代替方法A
public boolean includeAccount(String side) { Pair[] pairs = pairs(); return Stream.of(pairs).anyMatch(i -> { return i.from().equals(side) || i.to().equals(side); }); }