适用范围:在业务代码中有2个以上处理同一对象不同实现细节、属性一样不同实现细节都可以,
在Runnable(),Collection.sort(list,(x,y)-> xxxxxxxx)
Lambda 表达式中的参数类型都是由编译器推断得出的。Lambda 表达式中无需指定类型,
程序依然可以编译,这是因为 javac 根据程序的上下文,在后台推断出了参数的类型。
Lambda 表达式的类型依赖于上下文环境,是由编译器推断出来的。这就是所谓的“类型推断”
lambda 是一个匿名的函数 有使用前置条件
1.需要实现一个接口
2.需要的接口只有一个方法 即 函数式接口 可以标注一个注解 @FunctionalInterface 声明该接口是一个 函数式接口
引入了一个新的语法元素和操作符。这个操作符为 “->” , 该操作符被称为 Lambda 操作符或剪头操作符
左侧:指定了 Lambda 表达式需要的所有参数
右侧:指定了 Lambda 体,即 Lambda 表达式要执行的功能
在Java8中 Lambda提供了 许多常用可以实现的接口
public static void main(String[] args) {
//在单行lambda表达式中 可以省略return
//在单参数lambda中 可以省略左侧参数入参括号 “()”
//在多行内容体中 需要 大括号 “{}”
//语法格式1 没有参数 没有返回值
Runnable runnable = () -> System.out.println("Hello Lambda");
//语法格式2 有一个参数时 没有返回值
Consumer<String> consumer = x -> System.out.println(x.length());
//语法格式3 有两个参数时 有返回值的
Comparator<Integer> comparator = (x, y) -> x + y;
}
/**
* 利用lambda 进行策略模式
*/
@Test
public void test1() {
System.out.println(is(9, (x) -> x > 10));
}
private boolean is(Integer o, Onec<Integer> onec) {
return onec.run(o);
}
@FunctionalInterface
public interface Onec<T> {
boolean run(T t);
}