Java集合去重
✅ 方式一:TreeSet + Comparator
List 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 去重(适合多字段判断)
以某字段为
key建Map,保留第一个值
List 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,以 partyAId 作为 key,对象本身作为 value,并且会对重复 key 进行处理(保留第一个或最后一个)。 
 
 
 
.collect(Collectors.toMap(...))partyAId).values().stream().collect(Collectors.toList()) 
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 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 seen = new HashSet();List 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 去重).equals()equals + distinct())Set)

