浅析 Comparable 和 Comparator

简介: Comparable 和 Comparator的相同点和不同点

相同点


  • 都是用来实现集合中元素的比较从而进行排序。
  • compare(T o1, T      o2)     o1.compareTo(o2) 类似,定义排序规则后返回正数,零和负数分别代表大于,等于和小于。
  • 一个类要实现排序功能既可以通过内部实现 Comparable 接口也可以通过外部实现 Comparator 接口。


不同点


  • 接口定义位置不同
  • java.lang.Comparable
  • java.util.Comparator
  • 接口中定义方法不同
  • Comparable 中定义 public int compareTo(T o)
  • Comparator 中定义 public int compare(T o1, T o2)
  • 实现排序方式不同
  • Comparable 相对于内部比较器:通过类实现 Comparable 接口然后在类中重写 compareTo 方法实现排序功能。
  • Comparator 相对于外部比较器:在类外定义 Comparator 接口然后重写 compare 方法用于类比较进而实现排序功能。
  • 侧重点不同
  • Comparable 一般用于类的自然序,即默认的排序方式。比如学生默认以学号排序。
  • Comparator 则用于定制化排序,即拓展的排序方式。比如学生按照年龄排序。或者为没有实现 Comparable,即没有默认排序方式的类在不改变类自身结构的情况下提供一种比较方式。


示例

示例代码

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Student[] students = new Student[3];
        students[0] = new Student("lucy",21);
        students[1] = new Student("tom",23);
        students[2] = new Student("anna",25);
        // 使用默认的排序方式:以姓名排序
        // 由于实现了Comparable接口,所以可以直接使用Arrays.sort排序
        // Arrays.sort使用Comparable实现的内部比较器
        Arrays.sort(students);
        System.out.println("使用Comparable排序");
        for (Student student : students) {
            System.out.println(student);
        }
        System.out.println("===========================");
        // 使用扩展的排序方式:以年龄升序排序
        // 为Arrays.sort传入一个外部实现的Comparator比较器
        Arrays.sort(students, new Comparator<Student>() {
            @Override
            public int compare(Student s1, Student s2) {
                return Integer.compare(s1.age, s2.age);
            }
        });
        System.out.println("使用Comparator排序");
        for (Student student : students) {
            System.out.println(student);
        }
    }
}
class Student implements Comparable<Student> {
    public String name;
    public int age;
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
    @Override
    public int compareTo(Student o) {
        return this.name.compareTo(o.name);
    }
    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

示例结果

相关文章
|
数据采集 自然语言处理 文字识别
大模型升级与设计之道:ChatGLM、LLAMA、Baichuan及LLM结构解析(下)
大模型升级与设计之道:ChatGLM、LLAMA、Baichuan及LLM结构解析(下)
925 0
|
机器学习/深度学习 数据采集 人工智能
大模型升级与设计之道:ChatGLM、LLAMA、Baichuan及LLM结构解析(上)
大模型升级与设计之道:ChatGLM、LLAMA、Baichuan及LLM结构解析(上)
1272 0
|
弹性计算 运维 数据挖掘
DDD与微服务架构浅析
主要介绍DDD,微服务架构,以及两者之间的关系
DDD与微服务架构浅析
|
11月前
|
前端开发 数据可视化 搜索推荐
深入剖析极态云优雅的前端框架设计方案(上)
最近在体验极态云,这款低代码软件开发产品,发现其前端框架设计方案很优雅很强大! 在接下来的学习过程中,我将持续输出自己对极态云前端框架设计方案的深入理解,包括具体的使用技巧、优势分析以及可能的应用场景等方面的内容,希望能为大家提供有价值的参考。
|
11月前
|
机器学习/深度学习 自然语言处理 算法
多义词消歧
多义词消歧(WSD)是NLP中的重要任务,旨在确定词语在特定上下文中的确切含义。常用方法包括基于知识、统计、机器学习、深度学习、上下文嵌入、神经概率语言模型、图模型、规则、集成方法及跨语言消歧等。这些技术对于提升机器翻译、文本摘要、信息检索和问答系统的性能至关重要。
222 2
|
11月前
|
存储 SQL Docker
ClickHouse入门指南:快速搭建与使用
【10月更文挑战第26天】在大数据时代,如何高效地处理海量数据成为了许多企业和开发者的关注点。ClickHouse 是一个开源的列式数据库管理系统(Column-Oriented DBMS),以其出色的查询性能和高并发能力,在数据分析领域迅速崛起。本文将从一个初学者的角度出发,详细介绍如何快速上手 ClickHouse,涵盖从环境搭建到基础操作的全过程。
1196 3
|
SQL 数据库 C++
SQL 执行顺序,通俗易懂!
在数据库的世界里,SQL(Structured Query Language)是我们与数据对话的桥梁。编写一个高效的SQL查询,不仅要求我们理解数据库的结构和数据模型,还需要掌握SQL的执行顺序。但往往,这个顺序与我们在编写SQL时书写的顺序并不一致,这常常让初学者感到困惑。今天,我们就来用通俗易懂的方式,揭开SQL执行顺序的神秘面纱。
474 2
|
数据采集 存储 自然语言处理
LangChain实战:构建自定义问答助手
【8月更文第4天】随着自然语言处理(NLP)技术的发展,构建能够理解和回答复杂问题的问答助手变得越来越容易。LangChain 是一个强大的框架,它为开发人员提供了一套工具和模式,用于构建和部署基于语言模型的应用程序。本文将引导您通过 LangChain 构建一个自定义的问答助手,该助手可以理解并回答关于特定领域的复杂问题。
381 1
|
Java 程序员
深入理解Java匿名内部类的语法和使用场景
深入理解Java匿名内部类的语法和使用场景
|
项目管理 PHP 前端开发
推荐5款开源的协同办公软件
国内外开源的协同办公软件
17429 0