comparable和comparator

文章介绍了在Java中如何对对象进行排序,主要涉及两种方式:实现Comparable接口的自然排序和实现Comparator接口的定制排序。通过示例代码展示了如何在Product类中重写compareTo方法进行自然排序,以及如何创建Comparator实现类进行灵活的定制排序。比较了两者的特点,自然排序是单一且永久的,而定制排序则更灵活并可临时调整比较规则。
摘要由CSDN通过智能技术生成

1、实现对象的排序,可以考虑两种方法:自然排序(comparable)、定制排序(comparator)

2、方式一:实现Comparable接口的方式
如何判断当前类的对象的大小?
类可以实现comparable接口,重写compareTo方法


 @Override
    public int compareTo(Object o) {
        //先比较价格,价格相同,进行名字的比较
        if(o == this) return 0;
        if(o instanceof Product){
            Product p = (Product) o;
            int value = Double.compare(this.price,p.price);
            //从小到大
            if(value != 0) return value;
            //若想从大到小,return -
            return this.name.compareTo(p.name);
        }
        //手动抛出一个异常对象
        throw new RuntimeException("类型不匹配");
    }

实现步骤:
①具体的类A实现Comparable接口
②重写Comparable接口中的compareTo(Object obj)方法,在此方法中指明比较类A的对象的大小标准
③创建类A的多个实例,进行大小的比较或排序。Arrays.sort(arr);
3、方式二:实现Comparator接口的方式

 @Test
 public void test11() {
        Product[] arr = new Product[5];
        arr[0] = new Product("IQOO Neo6 se",3000);
        arr[1] = new Product("HuaWei",7000);
        arr[2] = new Product("Xiaomi",4000);
        arr[3] = new Product("Iphone",5000);
        arr[4] = new Product("Vivo",6000);
        Comparator comparator = new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
               if(o1 instanceof Product && o2 instanceof Product){
                    Product p1 = (Product) o1;
                    Product p2 = (Product) o2;
                    return Double.compare(p1.price,p2.price);
               }
               throw new RuntimeException("类型不匹配");
            }
        };
        Arrays.sort(arr,comparator);
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
    }

实现步骤:
①创建一个实现Comparator接口的实现类A
②实现类A重写Comparator接口中的抽象方法compare(Object o1,Object 02),在此方法中指明比较大小的对象的大小关系。
③创建实现类A的对象,并将此对象传入到相关方法的参数位置即可。Arrays.sort(arr,comparator类A的实例);

4、对比两种方式
自然排序:单一的、唯一的、一劳永逸,对应方法compareTo(Object obj)
定制排序:灵活的、多样的、临时的,对应方法是compare(Object o1,Object 02)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值