javaAPI(五):比较器Comparable和Comparator

前言

java中的对象,正常情况下,只能进行比较: == 或 != 。不能使用 > 或 < 的。但是再开发场景中,我们需要对多个对象进行排序,言外之意,就需要比较对象的大小。如何实现?使用两个接口中的一个。

Comparable(自然排序)

1、像String、包装类实现了Comparable接口,重写了compareTo(obj)方法,给出了比较两个对象大小的方式。

2、像String、包装类重写了compareTo()方法以后,进行了从小到大的排列。

3、重写compareTo()的规则:

如果当前对象this大于形参对象obj,则返回正整数,

如果当前对象this小于形参对象obj,则返回负整数,

如果当前对象this等于形参对象obj,则返回零。

java 复制代码
public void test(){
        String[] arr = new String[]{"AA","GG","XX","KK","BB"};
        Arrays.sort(arr);
        System.out.println(Arrays.toString(arr));//[AA, BB, GG, KK, XX]
    }

自定义类实现Comparable

对于自定义类来说,如果需要排序,我们可以让自定义类实现Comparable接口,重写compareTo() 方法。在compareTo()中指明如何排序。

自定义类中compareTo()

java 复制代码
//指明商品比较大小的方式:按照价格从低到高,再按照名称从低到高
    @Override
    public int compareTo(Object o) {
        if(o instanceof Goods){
            Goods goods = (Goods) o;
            //方式一
            if(this.price > goods.price){
                return 1;
            }else if(this.price < goods.price){
                return -1;
            }else{
                return -this.name.compareTo(goods.name);
            }
            //方式二
            //Double.compare(this.price,goods.price);
        }
        throw new RuntimeException("输入不准确");
    }

测试

java 复制代码
public void test2(){
        Goods[] arr = new Goods[5];
        arr[0] = new Goods("lenovo",44);
        arr[1] = new Goods("huawei",89);
        arr[2] = new Goods("xiaomi",55);
        arr[3] = new Goods("sanxing",10);
        arr[4] = new Goods("huashuo",10);

        Arrays.sort(arr);
        System.out.println(Arrays.toString(arr));
//[Goods{name='sanxing', price=10.0}, Goods{name='huashuo', price=10.0}, Goods{name='lenovo', price=44.0}, Goods{name='xiaomi', price=55.0}, Goods{name='huawei', price=89.0}]

    }

Comparator:定制排序

1、当元素类型没有实现java.lang.Comparable接口而又不方便修改代码,或者实现了java.lang.Comparator接口的排序规则不适合当前的操作,那么可以考虑使用Comparator的对象来排序

2、重写compare(Object o1,Object o2)方法,比较o1和o2的大小:

如果方法返回正整数,则表示o1大于o2;

返回负整数,表示o1小于o2;

如果返回0,表示相等。

java 复制代码
public void test3(){
        String[] arr = new String[]{"AA","GG","XX","KK","BB"};
        Arrays.sort(arr, new Comparator() {
            //按照字符串从大到小排序
            @Override
            public int compare(Object o1, Object o2) {
                if(o1 instanceof String && o2 instanceof String){
                    String s1 = (String) o1;
                    String s2 = (String) o2;
                    return -s1.compareTo(s2);
                }
                throw new RuntimeException("输入类型不匹配");
            }

        });
        System.out.println(Arrays.toString(arr));
    }

自定义类

java 复制代码
public void test4(){
        Goods[] arr = new Goods[5];
        arr[0] = new Goods("lenovo",44);
        arr[1] = new Goods("huawei",89);
        arr[2] = new Goods("xiaomi",55);
        arr[3] = new Goods("sanxing",10);
        arr[4] = new Goods("huashuo",10);

        Arrays.sort(arr, new Comparator() {
            //指明商品比较大小的方式:按照产品名称从低到高排序,再按照价格从高到低排序
            @Override
            public int compare(Object o1, Object o2) {
                if(o1 instanceof Goods && o2 instanceof Goods){
                    Goods goods1 = (Goods) o1;
                    Goods goods2 = (Goods) o2;
                    if(goods1.getName().equals(goods2.getName())){
                        return -Double.compare(goods1.getPrice(),goods2.getPrice());

                    }else {
                        return goods1.getName().compareTo(goods2.getName());
                    }
                }
                throw new RuntimeException("输入类型不匹配");
            }
        });
        System.out.println(Arrays.toString(arr));
    }

Comparable与Comparator对比

Comparable接口的方式一旦指定,保证Comparable接口实现类的对象在任何位置都可以比较大小。

Comparator接口属于临时性的比较。

相关推荐
2501_924890521 分钟前
商超场景徘徊识别误报率↓79%!陌讯多模态时序融合算法落地优化
java·大数据·人工智能·深度学习·算法·目标检测·计算机视觉
從南走到北41 分钟前
JAVA国际版东郊到家同城按摩服务美容美发私教到店服务系统源码支持Android+IOS+H5
android·java·开发语言·ios·微信·微信小程序·小程序
qianmoq1 小时前
第04章:数字流专题:IntStream让数学计算更简单
java
带只拖鞋去流浪2 小时前
Java集合(Collection、Map、转换)
java
超级小忍2 小时前
使用 GraalVM Native Image 将 Spring Boot 应用编译为跨平台原生镜像:完整指南
java·spring boot·后端
野犬寒鸦2 小时前
力扣hot100:搜索二维矩阵与在排序数组中查找元素的第一个和最后一个位置(74,34)
java·数据结构·算法·leetcode·list
cxyxiaokui0013 小时前
线程池的“变形记”:核心线程数居然能随时变大变小?
java·面试
灵魂猎手3 小时前
11. Mybatis SQL解析源码分析
java·后端·源码
努力的小郑4 小时前
别再说你会 new Object() 了!JVM 类加载的真相,绝对和你想的不一样
java·jvm·面试
cxyxiaokui0014 小时前
论如何优雅地让AI“闭嘴”:深入SpringAI的流式停止与记忆难题
java·后端