本套JAVA8教程由于是有英文翻譯過來的,如果有翻譯不對(duì)的地方還請(qǐng)多多包涵奕扣。
本節(jié)課先簡(jiǎn)單的介紹下Java8有哪些新特性,對(duì)于Java6/7版本做出哪些更改.那廢話不多說,趕緊開始今天的課程吧.
Lambda表達(dá)式 : 排序例子
Comparator<developer> byName = new Comparator<developer>() {
@Override
public int compare(Developer o1, Developer o2) {
return o1.getName().compareTo(o2.getName());
}
};
Lambda 表達(dá)式這樣操作.是不是簡(jiǎn)介了很多,還有更簡(jiǎn)明的寫法,先不要捉急,穩(wěn)扎穩(wěn)打.
Comparator<developer> byName =
(Developer o1, Developer o2)->o1.getName().compareTo(o2.getName());
下面寫一個(gè)不使用Lambda表達(dá)式來排序的方法
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class TestSorting {
public static void main(String[] args) {
List<developer> listDevs = getDevelopers();
System.out.println("排序之前");
for (Developer developer : listDevs) {
System.out.println(developer);
}
//通過名age排序
Collections.sort(listDevs, new Comparator<developer>() {
@Override
public int compare(Developer o1, Developer o2) {
return o1.getAge() - o2.getAge();
}
});
System.out.println("排序之后");
for (Developer developer : listDevs) {
System.out.println(developer);
}
}
private static List<developer> getDevelopers() {
List<developer> result = new ArrayList<developer>();
result.add(new Developer("mkyong", new BigDecimal("70000"), 33));
result.add(new Developer("alvin", new BigDecimal("80000"), 20));
result.add(new Developer("jason", new BigDecimal("100000"), 10));
result.add(new Developer("iris", new BigDecimal("170000"), 55));
return result;
}
}
輸出內(nèi)容
排序之前
Developer [name=mkyong, salary=70000, age=33]
Developer [name=alvin, salary=80000, age=20]
Developer [name=jason, salary=100000, age=10]
Developer [name=iris, salary=170000, age=55]
排序之后
Developer [name=jason, salary=100000, age=10]
Developer [name=alvin, salary=80000, age=20]
Developer [name=mkyong, salary=70000, age=33]
Developer [name=iris, salary=170000, age=55]
當(dāng)需要排序的數(shù)據(jù)發(fā)生變化的時(shí)候, 你只需要通過重寫匿名 Comparator 類來實(shí)現(xiàn) :
//通過age排序
Collections.sort(listDevs, new Comparator<developer>() {
@Override
public int compare(Developer o1, Developer o2) {
return o1.getAge() - o2.getAge();
}
});
//通過name排序
Collections.sort(listDevs, new Comparator<developer>() {
@Override
public int compare(Developer o1, Developer o2) {
return o1.getName().compareTo(o2.getName());
}
});
//通過Salary來排序
Collections.sort(listDevs, new Comparator<developer>() {
@Override
public int compare(Developer o1, Developer o2) {
return o1.getSalary().compareTo(o2.getSalary());
}
});
當(dāng)然這都是java8之前的啰嗦寫法. 這樣從邏輯上講沒有問題, 但是, 但是你想過沒有,你為了只改變一行代碼而創(chuàng)建了一個(gè)對(duì)象?是不是顯得很雞肋和笨重呢.
通過Lambda排序
在 Java 8里面, List 接口支持直接使用sort方法,再也不需要使用Collections.sort.
listDevs.sort(new Comparator<developer>() {
@Override
public int compare(Developer o1, Developer o2) {
return o2.getAge() - o1.getAge();
}
});
Lambda 表達(dá)式例子 :
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.List;
public class TestSorting {
public static void main(String[] args) {
List<User> listDevs = getList();
System.out.println("排序之前");
for (User user : listDevs) {
System.out.println(user);
}
System.out.println("排序之后");
//lambda 表達(dá)式!
listDevs.sort((User o1, User o2)->o1.getAge()-o2.getAge());
//java 8 , lambda也可以打印List
listDevs.forEach((user)->System.out.println(user));
}
private static List<User> getList() {
List<User> result = new ArrayList<User>();
result.add(new User("mkyong", new BigDecimal("70000"), 33));
result.add(new User("alvin", new BigDecimal("80000"), 20));
result.add(new User("jason", new BigDecimal("100000"), 10));
result.add(new User("iris", new BigDecimal("170000"), 55));
return result;
}
}
顛倒排序.
Comparator<User> salaryComparator = (o1, o2)->o1.getSalary().compareTo(o2.getSalary());
listDevs.sort(salaryComparator);
使用java8顛倒排序
Comparator<User> salaryComparator = (o1, o2)->o1.getSalary().compareTo(o2.getSalary());
listDevs.sort(salaryComparator.reversed());