Java去重排序之Comparable与Comparator的使用及说明
作者:debug4flaw 发布时间:2023-04-28 00:49:27
标签:Java,去重排序,Comparable,Comparator
一、排序与去重
日常工作中,总会有一些场景需要对结果集进行一些过滤。比如,与第三方交互后获取的结果集,需要再次排序去重,此时就会根据某个字段来去重,又或者某个字段来排序。
在Java中,去重的话,我们很容易就想到了Set的特性(无序无重),并且TreeSet(有序无重)还可以指定去重的规则(去重后一般是升序的结果集)。
排序的话,我们很容易想到各种排序算法,但Java中已经提供了排序的功能,如集合中sort()方法,并且还可以指定排序的字段和升降序。
在此多说一句,Set的特性(无序无重):
无序:无序性不是随机性,因为放入set中的元素,会根据元素的hash值来决定所放入的位置
无重:添加元素时 ,会按照元素的equals()进行判断,false认为两个元素不等时,才会添加
二、Comparable与Comparator的使用
public class CompareTest {
public static void main(String[] args) {
// 例如:从第三方返回的结果集
// 根据id去重,根据createTime降序排列
String result = "["
+ "{ \"id\": 1, \"createTime\": \"2022-12-21 13:23:59\"}"
+ "{ \"id\": 2, \"createTime\": \"2022-11-11 12:43:01\"}"
+ "{ \"id\": 1, \"createTime\": \"2022-12-21 11:20:50\"}"
+ "{ \"id\": 3, \"createTime\": \"2023-01-01 14:30:00\"}"
+ "]";
JSONArray examList = JSONArray.parseArray(result);
System.out.println("初始数据集:" + examList);
// 去重,利用set特性
Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id"));
Set<JSONObject> set = new TreeSet<>(comparator);
examList.forEach(jo -> set.add((JSONObject) jo));
// 此时的结果是,根据id去重,并且是升序的结果(自然排序)
System.out.println("去重结果:" + set);
// 此处为了,方便演示Comparable接口的作用,故把JSON映射成实体类,进行实现接口排序,其实sorted也可以使用Comparator排序
List<ExamInfo> collect = set.stream()
.map(jo -> JSONObject.toJavaObject(jo, ExamInfo.class))
.sorted()
.collect(Collectors.toList());
System.out.println("指定排序结果:" + collect);
}
}
public class ExamInfo implements Comparable<ExamInfo> {
private int id;
private String createTime;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getCreateTime() {
return createTime;
}
public void setCreateTime(String createTime) {
this.createTime = createTime;
}
@Override
public String toString() {
return "ExamInfo{" +
"id=" + id +
", createTime='" + createTime + '\'' +
'}';
}
@Override
public int compareTo(ExamInfo o) {
// 降序
return o.getCreateTime().compareTo(this.createTime);
}
}
关于排序升降序问题,Comparable与Comparator中的比较方法的返回值,大于0就交换。
所以参数顺序为a,b时:
若 a>b,即a-b>0,因为顺序是 a,b,交换后,b在前,a在后,排序顺序升序,即为自然排序;
// 升序
Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id"));
若 b>a,即b-a>0,因为顺序是 a,b,交换后,b在前,a在后,排序顺序降序。
@Override
public int compareTo(ExamInfo o) {
// 降序
return o.getCreateTime().compareTo(this.createTime);
}
三、区别
Comparable | Comparator | |
---|---|---|
所属包 | java.lang | java.util |
是否为函数式接口 | 是 | 是 |
比较的方法 | int compareTo(T o) | int compare(T o1, T o2) |
使用场景 | 比较的对象,自己可修改 | 比较的对象,自己不能修改,或者对象实现了Comparable接口,但比较规则不适用 |
来源:https://blog.csdn.net/weixin_45489731/article/details/129101912


猜你喜欢
- 在实际项目中,Java有时候需要调用C写出来的东西,除了JNI以外,我认为一种比较好的方法是JAVA调用Shell。先把C写出来的make成
- 本文介绍C#编程时,给定一个字符串,如何判断它是不是一个日期。本文将介绍两种方法,一个是判断字符串是否是时间,如果是就转换为一个时间变量,第
- 作为代码质量检查的流行工具,比如Sonarqube能够检查代码的“ * ”,跟代码结合起来能够更好地提高代码的质量,这篇文章将会介绍如何结合
- 一、RequestMapping注解RequestMapping注解的作用是建立请求URL和处理方法之间的对应关系RequestMappin
- 1.这是一个通过Java反射机制解析的工具类2.使用时只需创建对应的对象,并在Excel的第一行填上对应的属性名3.首先要添加相关的jar包
- java中this与super关键字的使用方法这几天看到类在继承时会用到this和super,这里就做了一点总结,与各位共同交流,有错误请各
- 1、概括在博客中,我们将讨论如何让Spring Security OAuth2实现使用JSON Web Tokens。2、Maven 配置首
- Spring Boot产生环形注入***************************APPLICATION FAILED TO STAR
- 目录Shiro简介Shiro快速入门SpringBoot-Shiro整合(最后会附上完整代码)附上最后的完整代码Shiro整合mybatis
- 本文实例讲述了java实现word文档转pdf并添加水印的方法。分享给大家供大家参考,具体如下:前段时间,项目需要自动生成word文档,用W
- 在开发中,可能会遇到一对多的关系,这个时候,一条sql语句就难以胜任这个任务了。只能先执行一条sql,然后根据返回的结果,再做一次sql关联
- 本文实例讲述了C#取得随机颜色的方法。分享给大家供大家参考。具体实现方法如下:public string GetRandomColor(){
- 使用System.Environment获取电脑的相关属性,入门案例,具体内容如下static void Main(string[] arg
- 最近比较无聊,随便翻着博客,无意中看到了有的人用VBS读文本内容,也就是读几句中文,emmm,挺有趣的,实现也很简单,都不需要安装什么环境,
- Android安全加密专题文章索引Android安全加密:对称加密Android安全加密:非对称加密Android安全加密:消息摘要Mess
- 最近开发了比较多的接口,因为没有可参考的案例,所以一开始一直按照我的理解进行开发。开发多了发现自己每个结果都写了相同的代码:try() {}
- 1. 场景描述本节结合springboot2、springmvc、mybatis、swagger2等,搭建一个完整的增删改查项目,希望通过这
- 在开发中,经常会遇到键盘挡住输入框的情况,比如登录界面或注册界面,弹出的软键盘把登录或注册按钮挡住了,用户必须把软键盘收起,才能点击相应按钮
- 一.简单介绍1.配置相关的依赖2.配置模式3写.mapper、controller、service4.配置yaml文件 配置mybatis全
- 使用wait()与notify()实现线程间协作1. wait()与notify()/notifyAll()调用sleep()和yield(