先说 Comparator 接口,这个理解了,下一个就理解了

一、Comparator 的用法(暂不考虑0,因为0不处理)

返回-1,1交换不交换位置,如果撇开比较器的两个参数和jdk默认顺序来说,存粹是错误的

接口如下:原文链接

public interface Comparator<T> {

    int compare(T o1, T o2);
}

现提出如下标准:

  • 标准1:jdk 默认要升序排列,即程序排序规则是 asc ,升序排列
  • 标准2:Comparator 接口第一个参数 o1 是第二个参数 o2 后面的对象

基于这 2 个标准,假设:

  • 1 = true
  • -1 = false

重点来了,有以下两种情况和处理方式:

  • 情况1:后面的比前面大,即 o1 > o2 ,是 标准1中的 升序 吗?是,返回 true,不交换前后位置。
  • 情况2:后面的比前面小,即 o1 < o2 ,是 标准1中的 升序 吗?不是,返回 false, 交换前后位置。

问:为什么第二种降序要交换前后位置?

答:因为 标准1 ,默认要对数组进行升序排列,如果发现降序的序列,自然要交换位置

扩散问题1:如果我想按降序排列呢?

答:那你就在升序时候返回 false,降序时候返回 true 就行

扩散问题2:如果我不比较,直接返回1或者-1呢?

答:因为标准1,返回1(true)代表都是升序,自然不必交换,返回-1(false)代表都不是升序,都要交换,即数组反转

总结:

想要升序排列,如果比较器2个参数是升序排列,就返回true,否则返回false即可

想要降序排列,如果比较器2个参数是降序排列,就返回true,否则返回false即可

附测试代码:

public class ComparatorDemo {

    private final int local;

    public ComparatorDemo(int local) {
this.local = local;
} @Override
public String toString() {
return "" + local;
} public static void main(String[] args) {
List<ComparatorDemo> asc = new ArrayList<>(); asc.add(new ComparatorDemo(13));
asc.add(new ComparatorDemo(3));
asc.add(new ComparatorDemo(15));
asc.add(new ComparatorDemo(18)); // 我想升序排列
asc.sort((second,first) -> {
if(second.local > first.local){
return 1; //是升序,返回true
}else if(second.local < first.local){
return -1; //是降序,返回false
}else {
return 0;
}
}); System.out.print("升序数组:");
System.out.println(asc); List<ComparatorDemo> desc = new ArrayList<>(); desc.add(new ComparatorDemo(13));
desc.add(new ComparatorDemo(3));
desc.add(new ComparatorDemo(15));
desc.add(new ComparatorDemo(18)); // 我想降序排列
desc.sort((o1,o2) -> {
if(o1.local > o2.local){
return -1; //不是降序,返回false
}else if(o1.local < o2.local){
return 1; //是降序,返回true
}else {
return 0;
}
}); System.out.print("降序数组:");
System.out.println(desc);
} }

二、Comparable 的用法(暂不考虑0,因为0不处理)

规则和 Comparator 一样,只需把当前 Comparable 实例当成Comparator#compare(T o1, T o2)第一个参数即可

测试代码:

public class ComparableImpl implements Comparable<ComparableImpl> {

    private final Integer local;

    public ComparableImpl(Integer num) {
this.local = num;
} @Override
public String toString() {
return "" + local;
} @Override
public int compareTo(ComparableImpl before) {
if (local > before.local) {
return 1; //是升序
} else if (local < before.local) {
return -1; //是降序
}
return 0;
} public static void main(String[] args) {
ComparableImpl[] ables = new ComparableImpl[]{
new ComparableImpl(1),
new ComparableImpl(13),
new ComparableImpl(25),
new ComparableImpl(4),
}; Arrays.sort(ables); System.out.println(Arrays.toString(ables));
} }

可能是最简单最通透的Comparable和Comparator接口返回值理解的更多相关文章

  1. 一直对zookeeper的应用和原理比较迷糊,今天看一篇文章,讲得很通透,分享如下(转)

    本文转自http://blog.csdn.net/gs80140/article/details/51496925 一直对zookeeper的应用和原理比较迷糊,今天看一篇文章,讲得很通透,分享如下: ...

  2. [No000062]读书八字诀:怎样将书读得通透?

    从吃透到通透 有种说法,吃透一本书,才算好好读过.然而比吃透境界更高,是通透.吃透仅限于书中内容,通透则是将书中内容与正反上下.古今中外背景知识相互关联. 当你做到读书通透,收获将远远大于手头那一本书 ...

  3. 看完这篇 Linux 权限后,通透了!

    我们在使用 Linux 的过程中,或多或少都会遇到一些关于使用者和群组的问题,比如最常见的你想要在某个路径下执行某个指令,会经常出现这个错误提示 . permission denied 反正我大概率见 ...

  4. 赌十包辣条,你一定没见过这么通透的ThreadLocal讲解

    1.看个热闹 鉴于普罗大众都喜欢看热闹,咱们先来看个热闹再开工吧! 场景一: 中午了, 张三.李四和王五一起去食堂大菜吃饭.食堂刚经营不久,还很简陋,负责打菜的只有一位老阿姨. 张三:我要一份鸡腿. ...

  5. 全网最通透的Java8版本特性讲解

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

  6. 简单介绍如何使用PowerMock和Mockito来mock 1. 构造函数 2. 静态函数 3. 枚举实现的单例 4. 选择参数值做为函数的返回值(转)

    本文将简单介绍如何使用PowerMock和Mockito来mock1. 构造函数2. 静态函数3. 枚举实现的单例4. 选择参数值做为函数的返回值5. 在调用mock出来的方法中,改变方法参数的值 一 ...

  7. 用Java构建一个简单的WebSocket聊天项目之新增HTTP接口调度

    采用框架 我们整个Demo基本不需要大家花费太多时间,就可以实现以下的功能. 用户token登录校验 自我聊天 点对点聊天 群聊 获取在线用户数与用户标签列表 发送系统通知 首先,我们需要介绍一下我们 ...

  8. 简单架构:反射实现抽象工厂+IDAL接口完全独立DAL

    一.普通架构中存在的问题 StudentDB数据库,包含一张StudentInfoTB表,结构如下: s_id int primary key identity(1,1), s_name Nvarch ...

  9. java:面向对象(多态,final,抽象方法,(简单工厂模式即静态方法模式),接口)

    * 生活中的多态:同一种物质,因环境不同而表现不同的形态. * 程序中多态:同一个"接口",因不同的实现而执行不同的操作. * 多态和方法的重写经常结合使用,子类重写父类的方法,将 ...

  10. 通透,23 个问题 TCP 疑难杂症全解析

    每个时代,都不会亏待会学习的人. 在进入今天主题之前我先抛几个问题,这篇文章一共提出 23 个问题. TCP 握手一定是三次?TCP 挥手一定是四次? 为什么要有快速重传,超时重传不够用?为什么要有 ...

随机推荐

  1. 【ACM算法竞赛日常训练】DAY2题解与分析【比赛】【数学考试】【简单瞎搞题】

    DAY2共三题: 比赛(概率) 数学考试(前缀和与思维) 简单瞎搞题(dp) 视频讲解:https://www.bilibili.com/video/BV1hP411o7RD/ 作者:Eriktse ...

  2. Teamcenter_NX集成开发:UF_UGMGR_invoke_pdm_server函数的使用

    之前了解到通过UFUN函数UF_UGMGR_invoke_pdm_server可以调用Teamcenter ITK函数,从而可以获取及编辑Teamcenter对象.UFUN中有样例代码,但是就是不知道 ...

  3. vue中实现video的动态src绑定

    Vue中实现video的动态src 试了网上的$refs方法发现并没有用 解决方案: 通过require方法  <div>     <video :src='url' @click= ...

  4. day04-SpringCloud Eureka-服务注册与发现01

    SpringCloud Eureka-服务注册与发现01 1.Eureka介绍 1.1学习Eureka前的说明 目前主流的服务注册&发现的组件是 Nacos,但是 Eureka 作为老牌经典的 ...

  5. 《花雕学AI》13:早出对策,积极应对ChatGPT带来的一系列风险和挑战

    ChatGPT是一款能和人类聊天的机器人,它可以学习和理解人类语言,也可以帮人们做一些工作,比如翻译.写文章.写代码等.ChatGPT很强大,让很多人感兴趣,也让很多人担心. 使用ChatGPT有一些 ...

  6. 飞桨paddlespeech语音唤醒推理C实现

    上篇(飞桨paddlespeech 语音唤醒初探)初探了paddlespeech下的语音唤醒方案,通过调试也搞清楚了里面的细节.因为是python 下的,不能直接部署,要想在嵌入式上部署需要有C下的推 ...

  7. API Gateway vs Load Balancer:选择适合你的网络流量管理组件

    本文从对比了 API Gateway 和 Load Balancer 的功能区别,帮助读者更好地了解他们在系统架构中扮演的角色. 作者陈泵,API7.ai 技术工程师. 原文链接 由于互联网技术的发展 ...

  8. 华为云 OpenTiny 跨端、跨框架企业级开源组件库项目落地实践直播即将开启!

    大家好,我是 Kagol,公众号:前端开源星球. "你们这个产品怎么只能在电脑上适配呀?我想在手机上看都不行,太麻烦了!!" "你们这个产品看起来太简单了,我想要@@功能 ...

  9. 33-webpack详细配置output

    const { resolve } = require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') module. ...

  10. Vue中实现数据列表无缝轮播

    类似这种滚动轮播效果 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta char ...