() -> System.out.println("2333");
左边:lambda形参列表(其实就是接口中的抽象方法的形参列表)
右边:lambda体(其实就是重写的抽象方法的方法体)
本质:作为接口的实例
一:无参,无返回值
public class LambdaTest1 {
@Test
public void test1(){
Runnable r1 = new Runnable() {
@Override
public void run() {
System.out.println("你爱我,我爱你,蜜雪冰城甜蜜蜜");
}
};
}
Runnable r2 = () -> System.out.println("2333");
}
二:一个参数,无返回值
@Test
public void test2() {
Consumer<String> con = new Consumer<String>() {
@Override
public void accept(String s) {
System.out.println(s);
}
};
con.accept("hello, 桂源铺");
Consumer<String> con1 = (String s) -> {
System.out.println(s);
};
con1.accept("233");
}
三:数据类型可以省略。因为可以由编译器推断得出,称为“类型推断”
@Test
public void test3(){
Consumer<String> con1 = new Consumer<String>() {
@Override
public void accept(String s) {
System.out.println(s);
}
};
con1.accept("2021.7.19");
Consumer<String> con2 = (s) -> {
System.out.println(s);
};
con2.accept("2021.7.19");
}
四:只需要一个参数时,参数的小括号可以省略
@Test
public void test5(){
Consumer<String> con1 = s -> {
System.out.println(s);
};
con1.accept("这里的小括号省略了嘿嘿");
}
五:需要两个或以上参数时,多条执行语句,并且可以有返回值
@Test
public void test6(){
Comparator<Integer> com1 = new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
System.out.println(o1);
System.out.println(o2);
return o1.compareTo(o2);
}
};
int cp1 = com1.compare(12,31);
System.out.println(cp1);
System.out.println("---------------");
Comparator<Integer> com2 = (o1, o2) -> {
System.out.println(o1);
System.out.println(o2);
return o1.compareTo(o2);
};
int cp2 = com2.compare(11, 21);
System.out.println(cp2);
}
六:当Lambda体只有一条语句时,return与大括号若有,都可以省略
@Test
public void test7(){
Comparator<Integer> com1 = (o1, o2) -> {
return o1.compareTo(o2);
};
Comparator<Integer> com2 = (o1, o2) -> o1.compareTo(o2);
}
总结:
左边:形参列表的参数类型可以省略(类型推断);如果Lambda形参列表只有一个参数,则小括号也可以省略;
右边:Lambda体映泰使用一对{}包裹。