首页 >Java >java教程 >Java 比较器与可比较指南及示例

Java 比较器与可比较指南及示例

Susan Sarandon
Susan Sarandon原创
2025-01-10 12:29:42192浏览

Java Comparator vs Comparable Guide with Example

想象一下您是一名 Java 程序员,您的任务是排序。好吧,你很幸运,因为 Java 没有一个而是两个排序超级英雄准备好拯救世界:ComparableComparator。但是,等等,这两个英雄相处得不太好——他们更像是亦敌亦友。那么,当分类恶棍进攻时,你应该呼叫哪一个呢?让我们来分解一下。

类似: 狮子狼

见见Comparable界面。就像一位总是坚持按照自己的方式做事的英雄。当你实现 Comparable 时,你是在说:“我知道如何对自己进行排序。”是的,实现 Comparable 的对象有自己的内置排序规则,有点像有自己的排序 GPS。交易如下:

  • 一招小马:你只能有一种排序方式。例如,如果您是 Person 类,并且您决定按年龄排序,那么除非您更改代码,否则您将陷入困境。这就像告诉每个人,“对不起,大家,我现在是一个‘按年龄排序’的人了。处理掉它!”
  • 自然顺序:您可以通过重写compareTo() 方法来定义自然顺序。这就像在说:“这是我的默认排序模式。你要么喜欢它,要么,好吧,太糟糕了!”

您需要一个编码示例吗?

public class Person implements Comparable<Person> {
    private String name;
    private int age;

    *// Implement compareTo*
    public int compareTo(Person other) {
        return        Integer.compare(this.age, other.age);
}

优点

  • 简单。只需在类上调用compareTo() 即可完成。
  • 当您有默认的排序方式并且不需要任何花哨的东西时,这很好。

缺点

  • 固执!您只能获得一种排序行为。想要按其他内容(例如名称)排序?太可惜了!

比较器:灵活的伙伴?

现在进入比较器——这个很酷、悠闲的伙伴,非常灵活。如果说比较者是独狼,那么比较者就是变色龙。它就像排序的瑞士军刀。不喜欢默认顺序?没问题,比较器可以让您按照自己喜欢的方式排序,而无需更改类本身!

  • 多种排序选项:您可以为不同的排序规则创建不同的比较器——年龄、姓名、身高等等!这就像有一个可以根据情况需要改变形状的助手。您今天想按名字排序吗?完毕!明天您想按身高排序吗?简单易行!
public class Person {
    private String name;
    private int age;

    *// Comparator for sorting by name*
    public static Comparator<Person> nameComparator = new Comparator<Person>() {
        public int compare(Person p1, Person p2) {
            return p1.name.compareTo(p2.name);
        }
    };

    *// Comparator for sorting by age*
    public static Comparator<Person> ageComparator = new Comparator<Person>() {
        public int compare(Person p1, Person p2) {
            return Integer.compare(p1.age, p2.age);
   }
  };
}

优点

  • 超级灵活。根据需要创建多种不同的排序策略。按年龄、姓名、身高排序,无论您喜欢什么!

  • 你不必搞乱原来的类。想要以完全不同的方式对对象进行排序而不触及源吗?比较器为您提供支持。

缺点

  • 比 Comparable 更详细一些。您必须为每个新的排序规则编写一个单独的比较器。

对峙:可比较者与比较者

让我们看看这两个人在正面交锋中的表现如何:

特征 可比较? ​​比较器?

  • 排序方法 对象对自身进行排序(仅一种方式) 单独的排序规则(多种方式) **在哪里实现 类本身内部 类外部(通常在单独的比较器中)。
  • 灵活性 一种排序方式 无限排序方式
  • 易于使用 单一排序规则更简单 更适合复杂/多重排序。
  • 修改现有类?是的,您修改类本身不,您保持类不变

那么,谁赢了? ?

这是平局! ?

  • 如果您正在处理具有清晰、自然的排序方式的对象,并且这种排序方法就是您所需要的,那么 Comparable 就是您的首选。这是经典的选择,就像黑色 T 恤一样,非常实用。

  • 但是,如果您的排序需求稍微复杂一点(您需要处理多个排序规则),或者您不想弄乱原始的类代码,那么 Comparator 就是您灵活、时尚的助手。就像戴上霓虹太阳镜——更多选择,更多乐趣!

最后的想法?

所以你就有了! Comparable 是您默认的一体化排序解决方案,而 Comparator 是您在事情变得有点疯狂时调用的适应性强的多用途助手。每个人都有自己的优点和缺点,所以在选择你的排序英雄之前请考虑一下手头的任务。

无论您选择哪一个,Java 中的排序从未如此酷。 ?

以上是Java 比较器与可比较指南及示例的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn