Comparable 和 Comparator

本文详细介绍了Java中的Comparable接口与Comparator接口,比较了它们在实现自然排序与自定义排序上的差异,强调了Comparable适用于单一条件排序的默认方式,以及Comparator提供更灵活的多条件排序和外部比较的特性。
摘要由CSDN通过智能技术生成

一.Comparable

  • 源码

    public interface Comparable<T> {
        int compareTo(T o);
    }
    
  • 返回值

    • 如果当前对象小于参数对象,则返回负整数。
    • 如果当前对象等于参数对象,则返回零。
    • 如果当前对象大于参数对象,则返回正整数。
  • 使用场景
    Comparable通常用于自然排序,例如,整数从小到大排序,字符串按字典顺序排序等。

  • example
    假设有一个Person类,我们希望按照年龄排序:

    public class Person implements Comparable<Person> {
        private int age;
    
        public Person(int age) {
            this.age = age;
        }
    
        @Override
        public int compareTo(Person other) {
            return this.age - other.age;
        }
    }
    

二. Comparator

  • 源码

    public interface Comparator<T> {
        int compare(T o1, T o2);
    }
    
  • 返回值

    • 如果o1小于o2,则返回负整数。
    • 如果o1等于o2,则返回零。
    • 如果o1大于o2,则返回正整数。
  • 使用场景
    Comparator用于自定义排序。当我们需要对同一类型的对象按不同的标准进行排序时,Comparator非常有用。

  • 示例
    对于上述的Person类,如果我们想按照姓名的字母顺序进行排序,我们可以这样做:

    public class NameComparator implements Comparator<Person> {
        @Override
        public int compare(Person p1, Person p2) {
            return p1.getName().compareTo(p2.getName());
        }
    }
    

三.对比

1. Comparable 接口

  • 内部比较法Comparable接口通常被实现在需要比较的对象的类定义中,它定义了对象的自然排序方法。如果一个类实现了Comparable接口,它必须定义compareTo方法,这个方法将用于所有基于该类对象的自然排序。
  • 单一条件排序:当类实现了Comparable,它的compareTo方法通常只基于一个单一的比较标准来排序。
  • 简单直接:实现Comparable接口的排序通常是对象的默认排序方式,直接通过Collections.sort()Arrays.sort()对实现了Comparable的对象列表进行排序,无需指定额外的比较器。

2. Comparator 接口

  • 外部比较法Comparator接口通常作为一个独立的类来实现,它定义了两个对象之间的比较方法。这允许开发者在不改变对象类的情况下,创建多种不同的比较方法。
  • 多条件排序:可以创建多个不同的Comparator实现类,每个实现类可以根据不同的属性或条件来比较同一类型的对象。
  • 更灵活Comparator在调用排序方法如Collections.sort()Arrays.sort()时需要显式指定。这使得在同一程序中可以有多种排序方式,特别是在比较标准经常变化或有多重排序标准的情况下。

总结

  • 用途:如果对象有一个自然的排序顺序(如数字、字母顺序等),通常使用Comparable。如果需要多种排序方式或者排序对象时不想修改对象的类,使用Comparator
  • 实现方式Comparable嵌入到类中,Comparator作为独立的实现。
  • 灵活性ComparatorComparable更灵活,提供了更多的控制权和定制排序选项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值