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

  • Post author:
  • Post category: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;
        }
    }
});



版权声明:本文为qq_42647903原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。