如何对 List集合进行排序

ゞ 浴缸里的玫瑰 2022-09-10 08:13 341阅读 0赞

对 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;
}
}

  1. 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());

发表评论

表情:
评论列表 (有 0 条评论,341人围观)

还没有评论,来说两句吧...

相关阅读

    相关 list进行排序

    我们在List里存入一些对象,比如person对象,若想要让这些对象按他们的age属性大小排序,不用我们自己实现,java已经帮我们实现了,我们只要实现Comparator接口