在开发中,需要对一组对象进行排序,是非常常见的需求。排序可以让数据更加有序,便于查找和操作。
在Java中,排序可以使用Collections类或Arrays类提供的方法
可以通过Comparable自然排序和Comparator定制排序进行实现
自然排序(Natural Ordering)也叫常规排序,是指使用Java对象默认的排序规则进行排序,例如整数默认按照数值大小升序排序,字符串默认按照字典序升序排序。
定制排序(Customized Ordering)是指使用自己定制的排序规则进行排序,例如按照字符串长度升序排序,或者按照对象某个属性的大小排序。
Comparator接口提供了一种定制排序的方式,它可以定义多种不同的排序规则,程序员可以根据需要选择不同的比较器实现类。而Comparable接口则提供了一种自然排序的方式,它只定义了一种比较规则,不能进行定制排序。
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}]
上述例子中,如果按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());
相同点: 在Java中,可以使用Comparator
和Comparable
接口来定义对象的排序方式。
不同点:
Comparable
接口是Java中的内部排序接口,它允许一个对象和另一个同类对象进行比较。当一个对象实现了Comparable
接口后,它可以和同类对象进行比较,而这个比较的方式是通过实现compareTo()
方法。compareTo()
方法返回一个int值,用于比较对象的大小关系,如返回-1表示小于,返回0表示相等,返回1表示大于。接口是Java中的外部排序接口,它允许对两个不同类的对象进行比较。
Comparator接口是一个独立的比较器,它不需要修改对象的类就可以对对象进行排序。使用
Comparator接口可以实现灵活的比较方式。一个实现了
Comparator接口的对象可以通过实现
compare()方法来定义自己的比较逻辑。因此,Comparable
是用于自然排序,通常是按照对象的内在属性来进行排序,而Comparator
是用于外部排序,通常是按照业务需求来进行排序,比如按照价格、时间等属性进行排序。
文章浏览阅读942次。1. 基本介绍 /dev/random和/dev/urandom是Linux系统中提供的随机伪设备,这两个设备的任务,是提供永不为空的随机字节数据流。很多解密程序与安全应用程序(如SSH Keys,SSL Keys等)需要它们提供的随机数据流。 这两个设备的差异在于:/dev/random的random pool依赖于系统中断,因此在系统的中断数不足时,/dev/random设备..._/dev/random 安全随机数
文章浏览阅读273次。可能很多人在大一的时候,就已经接触了递归了,不过,我敢保证很多人初学者刚开始接触递归的时候,是一脸懵逼的,我当初也是,给我的感觉就是,递归太神奇了!可能也有一大部分人知道递归,也能看的懂递归,但在实际做题过程中,却不知道怎么使用,有时候还容易被递归给搞晕。也有好几个人来问我有没有快速掌握递归的捷径啊。说实话,哪来那么多捷径啊,不过,我还是想写一篇文章,谈谈我的一些经验,或许,能够给你带来一些帮助..._递归 翻译字典 最佳实践
文章浏览阅读377次。Microsoft.NETFramework 4.5(在线安装 x86_x64)下载地址:点击这里!----------------------------------------------------------------------分割线---------------------------------------------------------------------------..._java的net包在哪下
文章浏览阅读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时,如果通过声明式异常处
文章浏览阅读1.7k次。背景最近项目中使用unix域数据报套接字实现线程间通信,在此总结一下。进程间通信进程间通信的方式很多,包括管道、FIFO、消息队列、信号量、共享内存unix域套接字等。管道一般是半双工的,只能在具有公共祖先的两个进程间使用。#include <unistd.h>int pipe(int fd[2]);/* 成功返回0,失败返回-1 */FIFO..._unix域协议应用
文章浏览阅读66次。 回顾周二A股行情,沪深两市整体呈现震荡反弹格局。沪指和深成指表现较为强势,全天呈现脉冲式上行格局,其中深成指涨幅超过1%,上证指数距离 3600点仅一步之遥;而创业板指开盘快速冲高,随后逐步回落,全天表现相对分化。 当前在成交量持续回落、宏观经济增速趋缓、海外风险仍存的背景下,建议更多关注具备防御性质的方向,业绩稳定、前期涨幅较小、三季报预计良好的方向存在一定的机会。 从技术面来看,周二沪指震荡走高收红,个股板块涨多跌少,赚钱效应偏好,两市成交额表现温和,预计短线大盘有望逐步震荡企稳,关注板块
文章浏览阅读244次。Springboot源码系列一、SpringApplication的构造方法springboot程序的一切都开始于main方法public static void main(String[] args) { SpringApplication.run(ZiyanApiApplication.class, args);}run方法中传入了两个参数一个是当前main方法的Class对象,一个是命令行的参数的数组,让我们来看看run方法中都做了哪些事情/** * Static helper
文章浏览阅读229次。LLM 技术图谱(LLM Tech Map)是将 LLM 相关技术进行系统化和图形化的呈现,此图谱主要特点是“专注于技术人视角”,不求从 LLM 产业角度汇聚信息,而是希望让从事相关工作或是想了解 LLM 的技术人有一个快速感知。LLM 技术图谱(LLM Tech Map)从基础设施、大模型、Agent、AI 编程、工具和平台,以及算力几个方面,为开发者整理了当前 LLM 中最为热门和硬核的技术领域以及相关的软件产品和开源项目。LLM 模型的训练和部署需要大量的算力,算力是 LLM 技术发展的关键因素。_llm tech map
文章浏览阅读765次。第2行储存的是序列信息,正常情况都是用ATCG四个字母表示,但是当测序仪无法准确分辨该位置的序列信息时,会以N来代指此处的序列信息;第4行存储的就是第2行每一个碱基的测序质量信息,其中的每一个符号所对应计算机的ASCII值是经过换算的phred值,而phred值等于33-10*logP,这里的P代表该位置测序发生错误的概率,简单来说,如果某个位置测得的序列十分可信,那么意味着该位置发生错误的概率极小,所以phred值就很大,即该值越大,说明测序的质量越好。明码标价之ATACseq|生信菜鸟团。_sra文件怎么打开
文章浏览阅读362次,点赞5次,收藏10次。打印转义字符、\ddd,表示1~3个八进制的数字
文章浏览阅读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
文章浏览阅读1k次,点赞20次,收藏23次。1.Synthesis(图形学上)合成:比如之前学过的光线追踪或者光栅化2.Capture(捕捉):把真实世界存在的东西捕捉成为照片。_相机视野经过棱镜后