一;去重
public static Predicate distinctByKey(Function super T, ?> keyExtractor) {
Map seen = new ConcurrentHashMap<>();
return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null;
}
distinct()不对对象列表进行去重的直接实现。它是hashCode()和equals()工作的
用Stream接口的 filter()接收为参数
List lists = list.stream().filter(distinctByKey(user->user.getUid())).collect(Collectors.toList());
二;去重
对象中的部分元素的重复
//long num = addList.stream().distinct().count();
long count = addList.stream().collect(Collectors.collectingAndThen(
Collectors.toCollection(() -> new TreeSet<>(
Comparator.comparing(po ->DateTimeFormatter.ofPattern("yyyy-MM-dd").format(po.getOrderTime()) + ";" + po.getCityCode()))), ArrayList::new)).stream().count();
Assert.checkBoolean(addList.size() == count, "Excel中,存在相同日期的城市活跃度");
DateTimeFormatter.ofPattern(“yyyy-MM-dd”).format(po.getOrderTime()):
是LocalDateTime 类型格式化
正常这样写:Comparator.comparing(p->p.getOrderTime() + “;” + p.getCityCode()))), ArrayList::new)
仅供学习参考