Set<String> unique = new HashSet<>();
List<String> duplicates = new ArrayList<>();
for (Animal cat: animals) {
if (!unique.add(cat.getName())) {
duplicates.add(cat.getName());
}
}
return duplicates;
我想知道是否有一种方法可以简化这个过程?我是Java streams的新手,我尝试过使用Map,但我还是求助于传统的for循环。
发布于 2018-08-08 03:03:01
我不知道这是否可以被认为是一种简化,但这里有一种使用streams的方法:
return animals.stream()
.collect(Collectors.groupingBy(Animal::getName))
.values()
.stream()
.flatMap(group -> group.stream().skip(1))
.map(Animal::getName)
.collect(Collectors.toList());
发布于 2018-08-08 02:49:25
不要重复发明轮子和使用像commns-collection.substract()这样的库
// I have not tested the code, but I think you get the idea
Set<> unique = new HashSet(animals)
Collection<> dublicates = CollectionUtil.subtract(animals, unique)
https://stackoverflow.com/questions/51733414
复制相似问题