lambda表达式就是用来简化函数式接口(Functional Interface)的
函数式接口:只有一个抽象方法的接口
例子1:无参函数的简写
// 创建一个线程
new Thread(new Runnable(){// 接口名
@Override
public void run(){// 方法名
System.out.println("Thread run()");
}
}).start();
上述代码给Tread
类传递了一个匿名的Runnable
对象,重载Runnable
接口的run()
方法来实现相应逻辑。这是JDK7以及之前的常见写法。匿名内部类省去了为类起名字的烦恼,但还是不够简化,在Java 8中可以简化为如下形式:
new Thread(
()->System.out.println("Thread run()")// 省略接口名和方法名
).start();
例子2:带参函数的简写
给一个字符串列表通过自定义比较器,按照字符串长度进行排序
// JDK7 匿名内部类写法
List<String> list = Arrays.asList("I","Love","You","Very","!");
Collections.sort(list, new Comparator<String>(){// 接口名
@Override
public int compare(String s1, String s2){// 方法名
if(s1 == null)
return -1;
if(s2 == null)
return 1;
return s1.length()-s2.length();
}
});
上述代码通过内部类重载了Comparator
接口的compare()
方法,实现比较逻辑。采用Lambda表达式可简写如下:
List list = Arrays.asList("I","Love","You","Very","!");
Collections.sort(list,(s1,s2) -> {// 省略参数表的类型
if(s1 == null)
return -1;
if(s2 == null)
return 1;
return s1.length()-s2.length();
})
简写的依据
1.使用Lambda表达式的依据必须有相应的函数式接口;
2.Lambda表达式另一个依据是 javac 的类型推断机制,在上下文信息足够的情况下,编译器可以推断出参数表的类型,而不需要显式指名;
注意:
Lambda表达式中不能修改外部的局部变量,即Lambda表达式中调用的外部变量应为final修饰的或实际不会改变的。
Lambda表达式中可以修改,静态变量或者数组,但使用静态变量应考虑线程同步问题。