一文真正搞懂Java中的自然排序和定制排序,到底升序还是降序

Posted 尚墨1111

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一文真正搞懂Java中的自然排序和定制排序,到底升序还是降序相关的知识,希望对你有一定的参考价值。

1. 自然排序

自然排序:类实现了java.lang.Comparable接口,重写compareTo()的规则

//这里固定指:o1表示位于前面的对象,o2表示后面的对象,并且表示o1比o2小
o1.compareTo(o2)
//升序
Collections.sort(persons, new Comparator<Person>() {
    @Override
    public int compare(Person o1, Person o2) {
    //o1比o2小,直接返回,就是不调整位置,所以是升序
        return o1.getAge().compareTo(o2.getAge());
    }
});

2.定制排序

定制排序:java.util.Comparator,重写compare方法

//这里o1表示位于前面的对象,o2表示后面的对象
compare(o1,o2)==o1.compareTo(o2)

返回-1(或负数),表示不需要交换0102的位置,o1依旧排在o2前面,asc,升序
返回1(或正数),表示需要交换0102的位置,o1排在o2后面,desc,降序

//Collections排序降序
Collections.sort(persons, new Comparator<Person>() {
    @Override
    public int compare(Person o1, Person o2) {
        return o2.getAge().compareTo(o1.getAge());//o2比o1小,所以是降序
    }
});

总览

Collections.sort(companyList, new Comparator<String>() {
    @Override
    public int compare(String o1, String o2) {
        if(o1.compareTo(o2) < 0 ){//o1比o2小,不调整位置,升序—-->升序
            return -1;
        }else if(o1.compareTo(o2) == 0){
            return 0;
        }else{//o2比o1小,调整整位置,降序——>升序
            return 1;
        }
    }
});

以上是关于一文真正搞懂Java中的自然排序和定制排序,到底升序还是降序的主要内容,如果未能解决你的问题,请参考以下文章

一文搞懂常见十大排序算法

一文搞懂常见十大排序算法

TreeSet ------自然排序与定制排序(比较器)

Java自用集合练习题:TreeSet的自然排序与定制排序

java TreeSet的排序之定制排序

Java_比较器