Arp*_*hur 6 lambda arraylist java-8 java-stream
我有两个对象:
public class ObjectOne {
private String id;
private String name;
private String school;
private String score; //Default score is null
..getters and setters..
}
public class ObjectTwo {
private String id;
private String marks;
..getters and setters..
}
Run Code Online (Sandbox Code Playgroud)
而且,我有上述对象的两个列表,
List<ObjectOne> listOne;
List<ObjectTwo> listTwo;
Run Code Online (Sandbox Code Playgroud)
如果ID相等,如何根据标准比较两个列表并为listOne的得分分配listTwo的分数。我知道,我们可以使用两个for循环来做。但是我想使用Java8流来实现它。
List<ObjectOne> result = new ArrayList<>();
for(ObjectOne one : listOne) {
for(ObjectTwo two : listTwo) {
if(one.getId().equals(two.getId())) {
one.setScore(two.getmarks());
result.add(one);
}
}
}
return result;
Run Code Online (Sandbox Code Playgroud)
如何使用Java8 lambda和流实现此功能?
令listOne.size()为N,listTwo.size()为M。那么2环求解的复杂度为O(M * N)。
我们可以listTwo通过id 索引将其减少为O(M + N)。
listTwo没有具有相同ID的对象// pair each id with its marks
Map<String, String> marksIndex = listTwo.stream().collect(Collectors.toMap(ObjectTwo::getId, ObjectTwo::getMarks));
// go through list of `ObjectOne`s and lookup marks in the index
listOne.forEach(o1 -> o1.setScore(marksIndex.get(o1.getId())));
Run Code Online (Sandbox Code Playgroud)
listTwo对象具有相同的ID final Map<String, List<ObjectTwo>> marksIndex = listTwo.stream()
.collect(Collectors.groupingBy(ObjectTwo::getId, Collectors.toList()));
final List<ObjectOne> result = listOne.stream()
.flatMap(o1 -> marksIndex.get(o1.getId()).stream().map(o2 -> {
// make a copy of ObjectOne instance to avoid overwriting scores
ObjectOne copy = copy(o1);
copy.setScore(o2.getMarks());
return copy;
}))
.collect(Collectors.toList());
Run Code Online (Sandbox Code Playgroud)
要实现copy方法,您要么需要创建一个新对象,然后一个一个地复制字段,但是在这种情况下,我更喜欢遵循Builder模式。它还会产生更多的“功能”代码。