首页 > 编程语言 >Java Comparable接口-自然排序

Java Comparable接口-自然排序

时间:2024-08-25 12:51:40浏览次数:18  
标签:Comparable Java 对象 age Person 排序 public

什么是Comparable排序接口?

Comparable 接口是 Java 提供的一个用于对象排序的机制,它允许类的实例自然排序,即定义对象的默认排序顺序。

Comparable 接口概述

Comparable 接口是属于 Java.lang 包。它主要作用是提供一个统一的比较方法,用于对类的对象进行排序。

作用:

自然排序:是指对象按照其自然顺序进行排序的一种方式。

  • 数字:按照数值的大小进行排序(如从小到大)。

  • 字符串:按照字母表的顺序进行排序(如从字母 AZ)。

  • 日期:按照时间的先后顺序进行排序(如从早到晚)。

特点:
  • 基于对象的内在特征: 自然排序是依据对象自身的属性来确定顺序。例如,对于一个 Person 类,其自然排序可能是按年龄进行的,因为年龄是 Person 类的一个内在特征。

  • 一致性: 自然排序的规则应当一致,确保排序结果稳定。即,相同的对象在排序后位置不变。

  • 自反性: 自然排序规则应当满足自反性:对象与自身比较应返回零。

  • 对称性: 如果对象 A 小于对象 B,那么 B 应该大于 A

  • 传递性: 如果对象 A 小于对象 B,而 B 小于对象 C,则 A 应该小于 C

Comparable 接口定义
public interface Comparable<T> {
    int compareTo(T o);
}
方法说明

compareTo(T o):这个方法用于比较当前对象与指定对象 o 的顺序。返回一个整数:

  • 负整数:当前对象小于指定对象。

  • :当前对象等于指定对象。

  • 正整数:当前对象大于指定对象。

实现自然排序的步骤

实现 Comparable 接口

为了实现自然排序,类需要实现 Comparable 接口,并覆盖 compareTo方法。例如,对于一个 Person 类,可以按年龄进行自然排序:

public class Person implements Comparable<Person> {
    private String name;
    private int age;
​
    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }
    //实现 compareTo 方法以定义排序规则,所以在使用的时候会调实现的 compareTo方法
    @Override
    public int compareTo(Person other) {
        //这个方法只会返回 负数 0 和正数
        return Integer.compare(this.age, other.age); // 按年龄排序
    }
​
    @Override
    public String toString() {
        return name + " (" + age + ")";
    }
}

使用自然排序

一旦类实现了 Comparable 接口并定义了自然排序规则,可以使用标准排序方法对对象进行排序:

import java.util.Arrays;
​
public class Main {
    public static void main(String[] args) {
        Person[] people = {
            new Person("Alice", 30),
            new Person("Bob", 25),
            new Person("Charlie", 35)
        };
​
        // 排序
        Arrays.sort(people);
​
        // 输出排序后的结果
        for (Person person : people) {
            System.out.println(person);
        }
    }
}

小结:

自然排序是指对象按照其类定义的默认顺序进行排序,这种顺序由类的 compareTo 方法决定。它是最直接、最常见的排序方式,适合用于默认的排序需求。

欧了,到这里我应该解释的差不多啦,我是南极,大胆做自己,活出精彩的人生

标签:Comparable,Java,对象,age,Person,排序,public
From: https://blog.csdn.net/ouhexie/article/details/141387141

相关文章

  • Java计算机毕业设计实体店管理系统(开题+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着消费市场的日益繁荣与消费者需求的多元化,实体店作为传统零售业态,正面临着前所未有的挑战与机遇。在电商冲击下,实体店需通过数字化转型来提升顾客......
  • java计算机毕业设计校园零食售卖系统小程序(开题+程序+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着数字化时代的到来,校园生活日益便捷化、智能化。在校园环境中,学生对于零食的需求量大且多样化,传统的线下零食售卖方式已难以满足学生随时随地、个......
  • java计算机毕业设计洗衣服务平台(开题+程序+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景:随着现代生活节奏的加快,人们对便捷、高效服务的需求日益增长,尤其是在日常生活琐事如衣物清洗方面。传统洗衣店受限于营业时间、地理位置及排队等候等......
  • Java线程池详解
    Java线程池解析在Java中有两种方式创建线程池,一种是直接使用Executors工具类创建预先定义好的线程池。一共有以下四种线程池newCachedThreadPool:可缓存的无边界的线程池,最大线程数Integer.MAX_VALUEpublicstaticExecutorServicenewCachedThreadPool(){returnnewTh......
  • JAVA毕业设计|(免费)springboot共享汽车管理系统包含文档代码讲解
    收藏点赞不迷路 关注作者有好处编号:springboot118springboot共享汽车管理系统开发语言:Java数据库:MySQL技术:Spring+SpringMVC+MyBatis工具:IDEA/Ecilpse、Navicat、Maven1.系统展示2.万字文档展示第5章系统详细设计5.1管理员模块的实现5.1.1用户信息管理共享......
  • Java毕设项目II基于Java的高校学生课堂考勤系统的设计与实现
    目录一、前言二、技术介绍三、系统实现四、论文参考五、核心代码六、源码获取全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末一、前言随着企业规模的持续扩大和业务的日益复杂......
  • Java毕设项目II基于Java的高校学生课堂考勤系统的设计与实现
    目录一、前言二、技术介绍三、系统实现四、论文参考五、核心代码六、源码获取全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末一、前言随着高等教育规模的不断扩大,学生考勤管理......
  • Java毕设项目II基于Java的学籍管理系统设计与实现
    目录一、前言二、技术介绍三、系统实现四、论文参考五、核心代码六、源码获取全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末一、前言在信息化教育快速发展的今天,传统的手工管......
  • (javaweb)springboot的底层原理
    目录一.配置优先级二.Bean的管理1.获取bean​编辑​编辑2.bean作用域3.第三方bean三.SpringBoot原理 自动配置原理原理分析:conditional: 自动配置案例:(自定义starter分析)总结一.配置优先级//命令行参数的优先级最高二.Bean的管理1.获取bean注入ioc......
  • (javaweb)登录功能的校验与认证
    目录1.基础登录功能2.登录校验概述登录认证:1.会话技术2.三种会话技术的对比1.cookie2.Session3.令牌技术登录校验JWT令牌1.令牌介绍2.生成和校验3.登录后下发令牌过滤器filter快速入门详解(执行流程拦截路径过滤器链)过滤器链拦截器Interceptor 快速入门......