Sort方法
今天在使用sort方法的时候发现,不同的继承Collection接口的sort方法有不同的排序表达式
ArrayList arrayList = new ArrayList<>();
arrayList.add(2);
arrayList.add(1);
arrayList.add(3);
arrayList.add(2);
arrayList.add(5);
arrayList.add(4);
arrayList.sort((o1, o2) -> o2 - o1); // 降序
arrayList.sort(Comparator.comparingInt(o -> o)) // 升序 当然也可以使用上面的lambda表达式:arrayList.sort((o1, o2) -> o1 - o2)
// 也可以使用Collection接口的比较类
arrayList.sort(new Comparator() {
@Override
public int compare(Integer o1, Integer o2) {
return o1 - o2; // 升序,降序可类似上述方法
}
});
也可以使用Collections工具类,只要是继承了Collection接口的类都可以使用这个方法来进行操作
// Collections类的构造方法是私有的,表示不能够被实例化
private Collections() {}
// Collections类的排序方法就直接使用Comparator类来做
Collections.sort(arrayList, new Comparator() {
@Override
public int compare(Integer o1, Integer o2) {
return o1 - o2;
}
});
当然其他类都类似这样的操作
ArrayList arrayList2 = new ArrayList<>();
arrayList2.add("abcd");
arrayList2.add("hbcd");
arrayList2.add("bbcd");
arrayList2.add("gbcd");
arrayList2.sort(String::compareTo); // 基本的升序排列
arrayList2.sort(Comparator.reverseOrder()); // 基本的降序排列
arrayList2.sort((o1, o2) -> o2.compareTo(o1)); // 可以这样使用降序排列
// 当然也可以使用Collections的sort工具方法,使用方式跟上述一致