如何对 List集合进行排序
对 List集合进行排序
我们可以采用这几种写法进行排序
java8排序 ,Comparator comparable
1.java8的
list.sorted(Comparator.comparing())
2.Comparator 比较器 要比较的对象本身没有比较能力 o1.age-o2.age (正序) o2.age-o1.age(倒序)
通常 写法:
1):
Collections.sort(list, new Comparator() {
@Override
public int compare(Dog o1, Dog o2) {
return o2.age - o1.age;
}
});
2): Collections.sort(list,new x());
class x implements Comparator{
@Override
public int compare(Dog o1, Dog o2) {
return o2.age-o1.age;
}
}
- comparable 对象本身就有比较能力 comparaTo
public class DogComparable implements Comparable{
@Override
public int compareTo(DogComparable o) {
return age-o.age;//按照年龄排序 新元素- 老元素 正序
}
/@Override
public int compareTo(DogComparable o) {
return name.compareTo(o.name);//按照姓名排序 新元素比上老元素 正序
}/
}
4.java8按照多个元素排序 然后倒序
.sorted(Comparator.comparing(VoucherDTO::getExpiredTime).thenComparing(VoucherDTO::getBindTime,Comparator.reverseOrder())).collect(Collectors.toList());
还没有评论,来说两句吧...