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
相关推荐
rabbit_pro5 小时前
Spring AI使用Ollama
java·人工智能·spring
Mike117.5 小时前
GBase 8a 物化视图依赖和 DDL 风险排查记录
java·服务器·前端
李少兄6 小时前
领域驱动设计与 Clean Code 的实践
java·数据库·领域驱动
存在的五月雨6 小时前
项目中 Vitest 配置详解:vitest.config.ts
开发语言·javascript·vue.js
野犬寒鸦6 小时前
Claude Code:终端AI编程助手全指南(附带指令全讲解)
开发语言·后端·面试·ai编程
淡笑沐白6 小时前
JavaScript零基础到精通
开发语言·javascript·ecmascript
Languorous.6 小时前
C++智能指针详解:原理、使用及避坑指南
开发语言·c++
老马95276 小时前
opencode7-桌面应用实战2
java·人工智能·后端
广州灵眸科技有限公司6 小时前
瑞芯微(EASY EAI)RV1126B yolov11-track多目标跟踪部署教程
linux·开发语言·网络·人工智能·yolo·机器学习·目标跟踪
李白的天不白6 小时前
大规模请求数据并发问题
java·前端·数据库