Java集合去重

✅ 方式一:TreeSet + Comparator

最优雅的一种,适用于对象中某个字段唯一的去重(如 partyAId

复制代码
List<PartyACompanyVO> result = contractDOS.stream()
    .map(contract -> {
        PartyACompanyVO vo = new PartyACompanyVO();
        vo.setPartyAId(contract.getPartyAId());
        vo.setPartyA(contract.getPartyA());
        return vo;
    })
    .collect(Collectors.collectingAndThen(
        Collectors.toCollection(() ->
            new TreeSet<>(Comparator.comparing(PartyACompanyVO::getPartyAId))
        ),
        ArrayList::new
    ));

✅ 方式二:用 Map 去重(适合多字段判断)

以某字段为 keyMap,保留第一个值

复制代码
List<PartyACompanyVO> result = contractDOS.stream()
    .map(contract -> {
        PartyACompanyVO vo = new PartyACompanyVO();
        vo.setPartyAId(contract.getPartyAId());
        vo.setPartyA(contract.getPartyA());
        return vo;
    })
    .collect(Collectors.toMap(
        PartyACompanyVO::getPartyAId, // 唯一键字段
        Function.identity(),
        (existing, replacement) -> existing // 保留第一个
    ))
    .values()
    .stream()
    .collect(Collectors.toList());

✅ 这一段确实返回的是一个 Map<String, PartyACompanyVO>partyAId 作为 key,对象本身作为 value,并且会对重复 key 进行处理(保留第一个或最后一个)。

步骤 操作 目的
.collect(Collectors.toMap(...)) 生成 Map,自动去重(key 是 partyAId
.values() 取出所有值(PartyACompanyVO 对象)
.stream() 转换为流
.collect(Collectors.toList()) 变成最终的 List
  • Function.identity():返回对象本身。

  • .values().stream():从 Map 拿到去重后的对象,再转回 List。

✅ 方式三:用 distinct() + 重写 equals & hashCode

适合对象整体去重

首先你要重写 PartyACompanyVO

复制代码
@Data
@EqualsAndHashCode(onlyExplicitlyIncluded = true)
public class PartyACompanyVO {
    @EqualsAndHashCode.Include
    private String partyAId;

    private String partyA;
}

List<PartyACompanyVO> result = contractDOS.stream()
    .map(contract -> {
        PartyACompanyVO vo = new PartyACompanyVO();
        vo.setPartyAId(contract.getPartyAId());
        vo.setPartyA(contract.getPartyA());
        return vo;
    })
    .distinct()
    .collect(Collectors.toList());

✅ 方式四:使用临时 Set 去重(简单直接)

复制代码
Set<String> seen = new HashSet<>();
List<PartyACompanyVO> result = contractDOS.stream()
    .map(contract -> {
        PartyACompanyVO vo = new PartyACompanyVO();
        vo.setPartyAId(contract.getPartyAId());
        vo.setPartyA(contract.getPartyA());
        return vo;
    })
    .filter(vo -> seen.add(vo.getPartyAId())) // 如果添加失败说明已存在
    .collect(Collectors.toList());

总结

场景 推荐方式
单字段去重,简洁优雅 ✅ 方式一(TreeSet + Comparator
需要 Map 结构或复杂合并逻辑 ✅ 方式二(Map 去重)
已有完整对象定义且支持 .equals() ✅ 方式三(重写 equals + distinct()
简单过滤,临时处理 ✅ 方式四(手动 Set
相关推荐
你怎么知道我是队长23 分钟前
C语言---头文件
c语言·开发语言
期待のcode28 分钟前
Java虚拟机的运行模式
java·开发语言·jvm
程序员老徐30 分钟前
Tomcat源码分析三(Tomcat请求源码分析)
java·tomcat
hqwest35 分钟前
码上通QT实战25--报警页面01-报警布局设计
开发语言·qt·qwidget·ui设计·qt布局控件
a程序小傲39 分钟前
京东Java面试被问:动态规划的状态压缩和优化技巧
java·开发语言·mysql·算法·adb·postgresql·深度优先
仙俊红41 分钟前
spring的IoC(控制反转)面试题
java·后端·spring
阿湯哥42 分钟前
AgentScope Java 集成 Spring AI Alibaba Workflow 完整指南
java·人工智能·spring
HellowAmy1 小时前
我的C++规范 - 玩一个小游戏
开发语言·c++·代码规范
小楼v1 小时前
说说常见的限流算法及如何使用Redisson实现多机限流
java·后端·redisson·限流算法
与遨游于天地1 小时前
NIO的三个组件解决三个问题
java·后端·nio