java 自定义排序【Comparator升序降序的记法】

环境

java: 1.7

需求

今天在写排序时,忘了是返回1,是正序,还是-1为正序。
或者说,正序或者降序我应该如何返回。

例子说明

Collections.sort(companyList, new Comparator<String>() {
                @Override
                public int compare(String o1, String o2) {
                    if(o1.compareTo(o2) < 0 ){
                        return -1;
                    }else if(o1.compareTo(o2) == 0){
                        return 0;
                    }else{
                        return 1;
                    }
                }
            });

说明:

我的记法:

顺序其实主要是看-1-1决定其是否要调整顺序:

if(o1.compareTo(o2) < 0 ){
    return ?;
}
//这里o1表示位于前面的字符,o2表示后面的字符
//上面的条件是,o1比o2小,这个时候,我们需要需要调整它们的顺序
//如果你想升序,那么o1比o2小就是我想要的;所以返回-1,类比成false;表示我不想调整顺序

//如果你想降序,那么o1比o2小不是我想要的;所以返回1,类比成true;表示我想调整顺序

这里o1表示位于前面的字符,o2表示后面的字符
上面的条件是,o1o2小,这个时候,我们需不需要调整它们的顺序:

如果你想升序,那么o1比o2小就是我想要的;所以返回-1,类比成false;表示我不想调整顺序
如果你想降序,那么o1比o2小不是我想要的;所以返回1,类比成true;表示我想调整顺序

以上纯属自我总结,没有任何官方参考依据。
自己的一种记法。。。

  • 44
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山鬼谣me

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值