java8系列之方法引用

时间:2022-11-11 20:05:52

概述

在java 8中,我们习惯于使用Lambda表达式,来表示函数接口得引用。有时候在函数接口中,调用的是已经存在的方法。在这种情况下,java8提供了一个简写语法,那就是方法引用,进一步简化Lambda表达式。

方法引用的形式

方法引用的语法结构:ClassName::methodName(注意:只需要写方法名,不需要写括号,因为这里并不调用该方法)

方法引用的四种形式

类型 示例
引用静态方法 ContainingClass::staticMethodName
引用某个对象的实例方法 containingObject::instanceMethodName
引用某个类型的任意对象的实例方法 ContainingType::methodName
引用构造方法 ClassName::new

public class Person {
public enum Sex{
MALE,FEMALE
}

    String name;
LocalDate birthday;
Sex gender;
String emailAddress;

public String getEmailAddress() {
return emailAddress;
}

public Sex getGender() {
return gender;
}

public LocalDate getBirthday() {
return birthday;
}

public String getName() {
return name;
}

public static int compareByAge(Person a,Person b){
return a.birthday.compareTo(b.birthday);
}

}

引用静态方法

Person [] persons = new Person[10];

//使用匿名类
Arrays.sort(persons, new Comparator<Person>() {
@Override
public int compare(Person o1, Person o2) {
return o1.birthday.compareTo(o2.birthday);
}
});

//使用lambda表达式
Arrays.sort(persons, (o1, o2) -> o1.birthday.compareTo(o2.birthday));

//使用lambda表达式和类的静态方法
Arrays.sort(persons, (o1, o2) -> Person.compareByAge(o1,o2));

//使用方法引用
//引用的是类的静态方法
Arrays.sort(persons, Person::compareByAge);

引用某个对象的实例方法

class ComparisonProvider{
public int compareByName(Person a,Person b){
return a.getName().compareTo(b.getName());
}

public int compareByAge(Person a,Person b){
return a.getBirthday().compareTo(b.getBirthday());
}
}

ComparisonProvider provider = new ComparisonProvider();

//使用lambda表达式
//对象的实例方法
Arrays.sort(persons,(a,b)->provider.compareByAge(a,b));

//使用方法引用
//引用的是对象的实例方法
Arrays.sort(persons, provider::compareByAge);

引用某个类型的任意对象的实例方法

String[] stringsArray = {"Hello","World"};

//使用lambda表达式和类型对象的实例方法
Arrays.sort(stringsArray,(s1,s2)->s1.compareToIgnoreCase(s2));

//使用方法引用
//引用的是类型对象的实例方法
Arrays.sort(stringsArray, String::compareToIgnoreCase);

引用构造方法

public static <T, SOURCE extends Collection<T>, DEST extends Collection<T>>
DEST transferElements(SOURCE sourceColletions, Supplier<DEST> colltionFactory) {
DEST result = colltionFactory.get();
for (T t : sourceColletions) {
result.add(t);
}
return result;
}
...

final List<Person> personList = Arrays.asList(persons);

//使用lambda表达式
Set<Person> personSet = transferElements(personList,()-> new HashSet<>());

//使用方法引用
//引用的是构造方法
Set<Person> personSet2 = transferElements(personList, HashSet::new);

使用场景

当一个Lambda表达式调用了一个已存在的方法

不适合使用场景

当我们需要往引用的方法传其它参数的时候