下面将Lambda表达式的使用共分为六种情况介绍,代码块上半部分为原有方式,下半部分为使用Lambda表达式的简化方式,从而使我们进一步体会使用Lambda表达式的便捷之处
①格式一:无参,无返回值
//在这里我们使用创建多线程的Runnable方法举例
//此为原有方式
Runnable r1 = new Runnable() {
@Override
public void run() {
System.out.println("111");
}
};
r1.run();
//此处为使用Lambda表达式的方式
Runnable r2 = () -> System.out.println("111");
r2.run();
②格式二: Lambda需一个参数,但无返回值
//此处我们调用Consumer类举例
Consumer<String> con1 = new Consumer<String>() {
@Override
public void accept(String s) {
System.out.println(s);
}
};
con1.accept("222");
Consumer<String> con2 = (String s) -> {
System.out.println(s);
};
con2.accept("222");
③格式三:数据类型可以省略,因为可由编译器推断得出,称为"类型推断"
Consumer<String> con3 = (String s) -> {
System.out.println(s);
};
con3.accept("333");
Consumer<String> con4 = (s) ->{
System.out.println(s);
};
con4.accept("333");
④格式四:Lambda表达式若只有一个参数,参数的括号也可以省略
Consumer<String> con5 = (s) ->{
System.out.println(s);
};
con5.accept("444");
Consumer<String> con6 = s -> {
System.out.println(s);
};
con6.accept("444");
⑤格式五:Lambda需两个或以上的参数,多条执行语句,并且可以有返回值
Comparator<Integer> com1 = new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
return o1.compareTo(o2);
}
};
System.out.println(com1.compare(12,21));
Comparator<Integer> com2 = (o1,o2) -> {
return o1.compareTo(o2);
};
System.out.println(com2.compare(12,21));
⑥格式六:当Lambda体只有一条语句时,return与大括号都可省略
Comparator<Integer> com2 = (o1,o2) -> {
return o1.compareTo(o2);
};
System.out.println(com2.compare(12,21));
Comparator<Integer> com3 = (o1,o2) -> o1.compareTo(o2);
System.out.println(com3.compare(12,21));
Lambda表达式用法的总结:
-> 左边:
Lambda形参列表的参数可以省略(类型推断);如果Lambda形参列表只有一个参数,其 ( ) 也可以省略
-> 右边:
Lambda体应使用一对 { } 包裹;如果只有一条执行语句(可能是return语句),省略这一对 { } 和return
注意:
如果省略 { } ,则必须同时省略return
Lambda表达式的本质:
Lambda表达式作为函数式接口的实例,其本质 是一个"语法糖"(指计算机语言中),由编译器推断并转换出常规代码