本套JAVA8教程由于是有英文翻译过来的,如果有翻译不对的地方还请多多包涵。
本节课先简单的介绍下Java8有哪些新特性,对于Java6/7版本做出哪些更改.那废话不多说,赶紧开始今天的课程吧.
Lambda表达式 : 排序例子
Comparator<developer> byName = new Comparator<developer>() {
@Override
public int compare(Developer o1, Developer o2) {
return o1.getName().compareTo(o2.getName());
}
};
Lambda 表达式这样操作.是不是简介了很多,还有更简明的写法,先不要捉急,稳扎稳打.
Comparator<developer> byName =
(Developer o1, Developer o2)->o1.getName().compareTo(o2.getName());
下面写一个不使用Lambda表达式来排序的方法
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;
}
}
输出内容
排序之前
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]
当需要排序的数据发生变化的时候, 你只需要通过重写匿名 Comparator 类来实现 :
//通过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());
}
});
当然这都是java8之前的啰嗦写法. 这样从逻辑上讲没有问题, 但是, 但是你想过没有,你为了只改变一行代码而创建了一个对象?是不是显得很鸡肋和笨重呢.
通过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 表达式例子 :
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 表达式!
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());
网友评论