一文真正搞懂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;
        }
    }
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值