Java中的Lambda表达式
1. 介绍
Java中的Lambda表达式是Java 8引入的一个重要特性,它提供了一种清晰、简洁的方式来表示只有一个抽象方法的接口(即函数式接口)的实例。
Lambda表达式基本语法
(parameters) -> expression
(parameters) -> { statements; }
- parameters:Lambda表达式的参数列表。参数的类型可以省略,如果只有一个参数,圆括号也可以省略。
- .expression 或 { statements; }:Lambda体。如果Lambda体只包含一个表达式,则该表达式的计算结果将自动返回(即隐式返回)。
- 如果包含多条语句,则必须用花括号括起来,并且可以通过return语句显式返回结果。
函数式接口:
- 函数式接口是指恰好只有一个抽象方法的接口。
- 函数式接口可以通过使用@FunctionalInterface注解来明确表示。
2. 举例说明
(1)这里以Comparator为例,Comparator就是一个函数式接口,其中含有一个抽象方法 :int compare(T o1, T o2);
说明:查看源码的时候可能会发现,Comparator里面还有一个equals方法,但是从Java 8开始,这里有一个特例,即Object类中的equals、hashCode和toString方法不视为接口中的抽象方法,因为任何接口的实现类都隐式地继承了Object类的方法。
(2)源码如下(jdk1.8)
大概意思就是:这个方法会比较其两个参数的顺序。当第一个参数小于、等于或大于第二个参数时,返回负整数、零或正整数。
(3)结合List.sort()方法就可以自定义排序了
Comparator的排序原理
List.sort的排序算法(通常是TimSort,一种改进的归并排序算法)会利用传入的Comparator对象来比较列表中的元素。
过程如下:
排序算法会反复调用Comparator的compare方法来比较两个元素,并根据比较结果来决定这两个元素的相对位置。通过不断地比较和交换元素,最终得到一个按照指定规则排序的列表。
public class TestLambda {
public static class Person {
public String name;
public int age;
public Person(String name, int age){
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "name: " + name + ", age: " + age;
}
}
public static void main(String[] args) {
List<Person> persons = new ArrayList<>();
persons.add(new Person("person1",18));
persons.add(new Person("person2",19));
// 根据年龄从大到小排序
persons.sort((a,b) -> b.age - a.age);
persons.forEach(System.out::println);
}
}