对集合中的对象进行排序分别实现Comparable和comparator接口

本文主要是介绍对集合中的对象进行排序分别实现Comparable和comparator接口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

public class Driver {private String name;private int age;private int driveAge;//驾龄public Driver(String name, int age, int driveAge) {super();this.name = name;this.age = age;this.driveAge = driveAge;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public int getDriveAge() {return driveAge;}public void setDriveAge(int driveAge) {this.driveAge = driveAge;}@Overridepublic String toString() {return "name=" + name + ", age=" + age + ", driveAge=" + driveAge;}}
public class Car implements Comparable<Car>{private String band;//品牌private double topSpeed;//最高速度private double price;//价格private Driver driver;//司机public Car(String band, double topSpeed, double price, Driver driver) {super();this.band = band;this.topSpeed = topSpeed;this.price = price;this.driver = driver;}public String getBand() {return band;}public void setBand(String band) {this.band = band;}public double getTopSpeed() {return topSpeed;}public void setTopSpeed(double topSpeed) {this.topSpeed = topSpeed;}public double getPrice() {return price;}public void setPrice(double price) {this.price = price;}public Driver getDriver() {return driver;}public void setDriver(Driver driver) {this.driver = driver;}@Overridepublic String toString() {return "band=" + band + ", topSpeed=" + topSpeed + ", price=" + price + ", driver=" + driver ;}@Overridepublic int compareTo(Car o) {int x=(int) (o.getTopSpeed()-this.getTopSpeed());return x;}}
public class CarDriverComparator implements Comparator<Car>{@Overridepublic int compare(Car o1, Car o2) {// TODO Auto-generated method stub//驾龄比较int num1=o2.getDriver().getDriveAge()-o1.getDriver().getDriveAge();//最大速度int num2=(int) (num1==0?o2.getTopSpeed()-o1.getTopSpeed():num1);return num2;}}
public class CarTest {public static void main(String[] args) {List<Car> list=new ArrayList<Car>();//创建4个司机对象Driver d1=new Driver("aa",23,12);Driver d2=new Driver("bb",24,10);Driver d3=new Driver("cc",25,12);Driver d4=new Driver("dd",26,17);//创建4个Car对象Car c1=new Car("宝马",120,120000,d1);Car c2=new Car("林肯",200,200000,d2);Car c3=new Car("红旗",100,100000,d3);Car c4=new Car("五菱",90,70000,d4);//添加到集合中list.add(c1);list.add(c2);list.add(c3);list.add(c4);//遍历输出System.out.println("输出集合元素:");Iterator<Car> c=list.iterator();while(c.hasNext()){System.out.println(c.next());}//comparable排序System.out.println("comparable排序(按照速度从大到小排序):");Collections.sort(list);for(Car x:list){System.out.println(x);}//comparator排序System.out.println("comparator排序(按照驾龄从大到小排序,如果驾龄相同,速度从大到小排序):");Collections.sort(list,new CarDriverComparator());for(Car x:list){System.out.println(x);}}
}

结果:

输出集合元素:
band=宝马, topSpeed=120.0, price=120000.0, driver=name=aa, age=23, driveAge=12
band=林肯, topSpeed=200.0, price=200000.0, driver=name=bb, age=24, driveAge=10
band=红旗, topSpeed=100.0, price=100000.0, driver=name=cc, age=25, driveAge=12
band=五菱, topSpeed=90.0, price=70000.0, driver=name=dd, age=26, driveAge=17
comparable排序(按照速度从大到小排序):
band=林肯, topSpeed=200.0, price=200000.0, driver=name=bb, age=24, driveAge=10
band=宝马, topSpeed=120.0, price=120000.0, driver=name=aa, age=23, driveAge=12
band=红旗, topSpeed=100.0, price=100000.0, driver=name=cc, age=25, driveAge=12
band=五菱, topSpeed=90.0, price=70000.0, driver=name=dd, age=26, driveAge=17
comparator排序(按照驾龄从大到小排序,如果驾龄相同,速度从大到小排序):
band=五菱, topSpeed=90.0, price=70000.0, driver=name=dd, age=26, driveAge=17
band=宝马, topSpeed=120.0, price=120000.0, driver=name=aa, age=23, driveAge=12
band=红旗, topSpeed=100.0, price=100000.0, driver=name=cc, age=25, driveAge=12
band=林肯, topSpeed=200.0, price=200000.0, driver=name=bb, age=24, driveAge=10

这篇关于对集合中的对象进行排序分别实现Comparable和comparator接口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/890915

相关文章

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php