java8 对Collections 的sort排序:
List<Integer> list = Arrays.asList(1,3,2);
list.sort((Integer a, Integer b)-> a.compareTo(b));
//还可以去掉Integer
//list.sort((a, b)-> a.compareTo(b));
//甚至还可以简化
//list.sort(Integer::compareTo);
//还可以这么写
//list.sort(comparing(Integer::intValue));
System.out.println("小到大" + list.toString());
list.sort((Integer a, Integer b)-> b.compareTo(a));
//list.sort(comparing(Integer::intValue).reversed());
System.out.println("大到小" + list.toString());
对比之前的写法:
List<Integer> list = Arrays.asList(1,3,2);
list.sort(new Comparator<Integer>() {
@Override
public int compare(Integer a, Integer b) {
return a.compareTo(b);
}
});
System.out.println("小到大" + list.toString());
list.sort(new Comparator<Integer>() {
@Override
public int compare(Integer a, Integer b) {
return b.compareTo(a);
}
});
System.out.println("大到小" + list.toString());
输出:
可见java8 的lambda表达式多么简洁!