Java8的Lambda和排序
對數(shù)組和集合進(jìn)行排序是Java 8 lambda令人驚奇的一個應(yīng)用,我們可以實現(xiàn)一個Comparators來實現(xiàn)各種排序。
看下面案例:
static class Person {
final String firstName;
final String lastName;
Person(String firstName, String lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
@Override
public String toString() {
return "Person{" +
"firstName='" + firstName + '\'' +
", lastName='" + lastName + '\'' +
'}';
}
}
Person的數(shù)據(jù)有:
List<Person> people =
Arrays.asList(
new Person("Jane", "Henderson"),
new Person("Michael", "White"),
new Person("Henry", "Brighton"),
new Person("Hannah", "Plowman"),
new Person("William", "Henderson")
);
我們希望根據(jù)名字排序(last name),然后再根據(jù)姓(first name)排序。
在Java 7之前,我們通常是通過實現(xiàn)一個Comparator:
people.sort(new Comparator<Person>() {
@Override
public int compare(Person o1, Person o2) {
int result = o1.lastName.compareTo(o2.lastName);
if (result == 0)
result = o1.firstName.compareTo(o2.firstName);
return result;
}
});
people.forEach(System.out::println);
而在Java 8中,我們可以使用lambda替代匿名函數(shù),如下:
Comparator<Person> c = (p, o) -> p.lastName.compareTo(o.lastName); c = c.thenComparing((p, o) -> p.firstName.compareTo(o.firstName)); people.sort(c); people.forEach(System.out::println);
在這里,Lambda表達(dá)式 (p, o) -> p.lastName.compareTo(o.lastName)替代之前的匿名函數(shù)new Comparator<Person>() {}
因為Java編譯器并不能推遲對Lambda表達(dá)式類型判斷,比如延遲到將comparator傳遞到sort()方法,因此使得我們進(jìn)行鏈?zhǔn)?code>Comparator書寫有點困難,
比如我們想寫成如下:
XXX.thenComparing((p, o) -> p.lastName.compareTo(o.lastName))
.thenComparing((p, o) -> p.firstName.compareTo(o.firstName))
換句話說,類型判斷是從左到右,而不是從右到左,我們可以通過創(chuàng)建一個泛型來進(jìn)行類型推斷:
class Utils {
static <E> Comparator<E> compare() {
return (e1, e2) -> 0;
}
}
通過上面的compare()方法,我們可以書寫流暢的comparator鏈:
people.sort(
Utils.<Person>compare()
.thenComparing((p, o) ->
p.lastName.compareTo(o.lastName))
.thenComparing((p, o) ->
p.firstName.compareTo(o.firstName))
);
people.forEach(System.out::println);
到此這篇關(guān)于Java8的Lambda和排序的文章就介紹到這了,更多相關(guān)Java Lambda和排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?BeanPostProcessor后處理器源碼解析
這篇文章主要介紹了Spring?BeanPostProcessor后處理器源碼解析,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-09-09
Springboot?內(nèi)部服務(wù)調(diào)用方式
這篇文章主要介紹了Springboot?內(nèi)部服務(wù)調(diào)用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
如何正確控制springboot中bean的加載順序小結(jié)篇
這篇文章主要介紹了如何正確控制springboot中bean的加載順序總結(jié),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
如何解決java.net.BindException:地址已在使用問題
當(dāng)Zookeeper啟動報錯“java.net.BindException:地址已在使用”時,通常是因為指定的端口已被其他進(jìn)程占用,解決這個問題需要按照以下步驟操作:首先,使用命令如lsof -i:2181找到占用該端口的進(jìn)程號;其次,使用kill命令終止該進(jìn)程2024-09-09

