Java如何使用排序_java什么叫自然顺序-程序员宅基地

技术标签: jvm  java  数据结构  

排序的介绍

为什么需要排序

在开发中,需要对一组对象进行排序,是非常常见的需求。排序可以让数据更加有序,便于查找和操作。

在Java中,排序可以使用Collections类或Arrays类提供的方法

可以通过Comparable自然排序和Comparator定制排序进行实现

为什么叫自然排序和定制排序

自然排序(Natural Ordering)也叫常规排序,是指使用Java对象默认的排序规则进行排序,例如整数默认按照数值大小升序排序,字符串默认按照字典序升序排序。

定制排序(Customized Ordering)是指使用自己定制的排序规则进行排序,例如按照字符串长度升序排序,或者按照对象某个属性的大小排序。

Comparator接口提供了一种定制排序的方式,它可以定义多种不同的排序规则,程序员可以根据需要选择不同的比较器实现类。而Comparable接口则提供了一种自然排序的方式,它只定义了一种比较规则,不能进行定制排序。

使用Comparator定制排序

Java中可以使用java.util.Collections类提供的sort()方法或java.util.Arrays类提供的sort()方法对一组对象进行排序。这些方法使用的是默认的自然排序规则,如果需要自定义排序规则,则可以使用Comparator接口来实现自定义比较器。以下是一个简单的例子:

假设我们有一个名为Person的类,其中有两个属性:姓名和年龄。

@Data
public class Person {
    
    private String name;
    private int age;
}

现在我们有一个List对象,其中包含了若干个Person对象,我们可以使用Collections.sort()方法对它们进行排序:

List<Person> personList = new ArrayList<>();
personList.add(new Person("Alice", 20));
personList.add(new Person("Bob", 18));
personList.add(new Person("Charlie", 25));
personList.add(new Person("David", 23));

Collections.sort(personList, new Comparator<Person>() {
    
    @Override
    public int compare(Person o1, Person o2) {
    
        return o1.getName().compareTo(o2.getName());
    }
});

System.out.println(personList);

这个例子中我们按照Person对象的name属性进行升序排序,输出结果为:

[Person{name='Alice', age=20}, Person{name='Bob', age=18}, Person{name='Charlie', age=25}, Person{name='David', age=23}]

使用Comparable自然排序

上述例子中,如果按age排序呢?

如果要按照 age 属性排序,可以实现 Comparable 接口并重写 compareTo 方法,或者使用 Comparator 接口并重写 compare 方法。

首先,实现 Comparable 接口的方式是在类中添加 implements Comparable,然后重写 compareTo 方法。示例代码如下:

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

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }

    @Override
    public int compareTo(Person other) {
        return Integer.compare(this.age, other.age);
    }
}

在这个示例中,compareTo 方法根据 age 属性的大小来比较 Person 对象。调用 Collections.sort 方法就可以对 Person 对象集合进行排序,如下所示:

List<Person> people = new ArrayList<>();
people.add(new Person("Alice", 25));
people.add(new Person("Bob", 30));
Collections.sort(people);

如果要按照 age 属性排序,也可以使用 Comparator 接口,并重写 compare 方法。示例代码如下:

public class PersonAgeComparator implements Comparator<Person> {
    
    @Override
    public int compare(Person p1, Person p2) {
    
        return Integer.compare(p1.getAge(), p2.getAge());
    }
}

在这个示例中,compare 方法根据 age 属性的大小来比较 Person 对象。要对 Person 对象集合进行排序,需要在调用 Collections.sort 方法时传入 Comparator 对象,如下所示:

List<Person> people = new ArrayList<>();
people.add(new Person("Alice", 25));
people.add(new Person("Bob", 30));
Collections.sort(people, new PersonAgeComparator());

Comparator和Comparable的区别

相同点: 在Java中,可以使用ComparatorComparable接口来定义对象的排序方式。

不同点:

  • Comparable接口是Java中的内部排序接口,它允许一个对象和另一个同类对象进行比较。当一个对象实现了Comparable接口后,它可以和同类对象进行比较,而这个比较的方式是通过实现compareTo()方法。compareTo()方法返回一个int值,用于比较对象的大小关系,如返回-1表示小于,返回0表示相等,返回1表示大于。
  • Comparator接口是Java中的外部排序接口,它允许对两个不同类的对象进行比较。Comparator接口是一个独立的比较器,它不需要修改对象的类就可以对对象进行排序。使用Comparator接口可以实现灵活的比较方式。一个实现了Comparator接口的对象可以通过实现compare()方法来定义自己的比较逻辑。

因此,Comparable是用于自然排序,通常是按照对象的内在属性来进行排序,而Comparator是用于外部排序,通常是按照业务需求来进行排序,比如按照价格、时间等属性进行排序。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_49149614/article/details/130549533

智能推荐

Linux系统产生随机数/dev/random 和 /dev/urandom_/dev/random 安全随机数-程序员宅基地

文章浏览阅读942次。1. 基本介绍    /dev/random和/dev/urandom是Linux系统中提供的随机伪设备,这两个设备的任务,是提供永不为空的随机字节数据流。很多解密程序与安全应用程序(如SSH Keys,SSL Keys等)需要它们提供的随机数据流。  这两个设备的差异在于:/dev/random的random pool依赖于系统中断,因此在系统的中断数不足时,/dev/random设备..._/dev/random 安全随机数

递归最佳实践_递归 翻译字典 最佳实践-程序员宅基地

文章浏览阅读273次。可能很多人在大一的时候,就已经接触了递归了,不过,我敢保证很多人初学者刚开始接触递归的时候,是一脸懵逼的,我当初也是,给我的感觉就是,递归太神奇了!可能也有一大部分人知道递归,也能看的懂递归,但在实际做题过程中,却不知道怎么使用,有时候还容易被递归给搞晕。也有好几个人来问我有没有快速掌握递归的捷径啊。说实话,哪来那么多捷径啊,不过,我还是想写一篇文章,谈谈我的一些经验,或许,能够给你带来一些帮助..._递归 翻译字典 最佳实践

java库net2.0下载_.NET Framework各版本独立下载.NET Framework 3.5下载.NET Framework 2.0下载...-程序员宅基地

文章浏览阅读377次。Microsoft.NETFramework 4.5(在线安装 x86_x64)下载地址:点击这里!----------------------------------------------------------------------分割线---------------------------------------------------------------------------..._java的net包在哪下

小白初学JSP_2(Filter过滤器,Listener监听器、登入案例)_16、@webfilter注解的dispatchertypes属性值为error时,如果通过声明式异-程序员宅基地

文章浏览阅读401次。Servlet、Filter、Listener为JavaWeb的三大组件 文章目录 一、Filter:过滤器1.1 概念1.2 快速入门1.3 过滤器细节1.3.1 web.xml配置1.3.2 过滤器执行流程1.3.3 过滤器生命周期方法1.3.4 过滤器配置详解1.3.5 过滤器链(配置多个过滤器) 二、Listener:监听器2.1 概念2.2 ServletContextListener 一、Filter:过滤器 1.1 概念 web中的过滤器:当访问服务器的资源时,过_16、@webfilter注解的dispatchertypes属性值为error时,如果通过声明式异常处

进程间通信的利器——unix域套接字编程详解_unix域协议应用-程序员宅基地

文章浏览阅读1.7k次。背景最近项目中使用unix域数据报套接字实现线程间通信,在此总结一下。进程间通信进程间通信的方式很多,包括管道、FIFO、消息队列、信号量、共享内存unix域套接字等。管道一般是半双工的,只能在具有公共祖先的两个进程间使用。#include &lt;unistd.h&gt;int pipe(int fd[2]);/* 成功返回0,失败返回-1 */FIFO..._unix域协议应用

新玺配资:尚未形成趋势主线 困境下的策略曝光-程序员宅基地

文章浏览阅读66次。 回顾周二A股行情,沪深两市整体呈现震荡反弹格局。沪指和深成指表现较为强势,全天呈现脉冲式上行格局,其中深成指涨幅超过1%,上证指数距离 3600点仅一步之遥;而创业板指开盘快速冲高,随后逐步回落,全天表现相对分化。  当前在成交量持续回落、宏观经济增速趋缓、海外风险仍存的背景下,建议更多关注具备防御性质的方向,业绩稳定、前期涨幅较小、三季报预计良好的方向存在一定的机会。  从技术面来看,周二沪指震荡走高收红,个股板块涨多跌少,赚钱效应偏好,两市成交额表现温和,预计短线大盘有望逐步震荡企稳,关注板块

随便推点

Springboot源码系列-程序员宅基地

文章浏览阅读244次。Springboot源码系列一、SpringApplication的构造方法springboot程序的一切都开始于main方法public static void main(String[] args) { SpringApplication.run(ZiyanApiApplication.class, args);}run方法中传入了两个参数一个是当前main方法的Class对象,一个是命令行的参数的数组,让我们来看看run方法中都做了哪些事情/** * Static helper

LLM 大模型技术图谱(LLM Tech Map)-程序员宅基地

文章浏览阅读229次。LLM 技术图谱(LLM Tech Map)是将 LLM 相关技术进行系统化和图形化的呈现,此图谱主要特点是“专注于技术人视角”,不求从 LLM 产业角度汇聚信息,而是希望让从事相关工作或是想了解 LLM 的技术人有一个快速感知。LLM 技术图谱(LLM Tech Map)从基础设施、大模型、Agent、AI 编程、工具和平台,以及算力几个方面,为开发者整理了当前 LLM 中最为热门和硬核的技术领域以及相关的软件产品和开源项目。LLM 模型的训练和部署需要大量的算力,算力是 LLM 技术发展的关键因素。_llm tech map

从SRA数据下载开始学习ATACseq数据分析_sra文件怎么打开-程序员宅基地

文章浏览阅读765次。第2行储存的是序列信息,正常情况都是用ATCG四个字母表示,但是当测序仪无法准确分辨该位置的序列信息时,会以N来代指此处的序列信息;第4行存储的就是第2行每一个碱基的测序质量信息,其中的每一个符号所对应计算机的ASCII值是经过换算的phred值,而phred值等于33-10*logP,这里的P代表该位置测序发生错误的概率,简单来说,如果某个位置测得的序列十分可信,那么意味着该位置发生错误的概率极小,所以phred值就很大,即该值越大,说明测序的质量越好。明码标价之ATACseq|生信菜鸟团。_sra文件怎么打开

C语言打印转义字符-程序员宅基地

文章浏览阅读362次,点赞5次,收藏10次。打印转义字符、\ddd,表示1~3个八进制的数字

技术点记录_hive timediff-程序员宅基地

文章浏览阅读965次。函数Hive的内置函数数学函数取整函数:round、floor、ceil、fixfix朝零方向取整,如fix(-1.3)=-1; fix(1.3)=1;floor:地板数,所以是取比它小的整数,即朝负无穷方向取整,如floor(-1.3)=-2; floor(1.3)=1; floor(-1.8)=-2; floor(1.8)=1。ceil:天花板数,也就是取比它大的最小整数,即朝正无穷方向取整,如ceil(-1.3)=-1; ceil(1.3)=2; ceil(-1.8)=-1; ceil_hive timediff

19.相机,棱镜和光场_相机视野经过棱镜后-程序员宅基地

文章浏览阅读1k次,点赞20次,收藏23次。1.Synthesis(图形学上)合成:比如之前学过的光线追踪或者光栅化2.Capture(捕捉):把真实世界存在的东西捕捉成为照片。_相机视野经过棱镜后