我有类似的方法:
private X findMatchingValuesInStream(Stream<DocumentDto> a, Stream<FolderDto> b) {
// TODO: return Pairs matched by documentDto.url and folderDto.url
}
我知道url
字段中只有一个匹配项,我想返回一个具有匹配项的对。
例如,如果我们设置了documentDto
和url="asasa"
和其他一些字段,而folderDto
和url="asasa"
和其他一些字段被设置了,我想返回例如这些元素。
最后,我的方法将返回这些元素的List
。
我不确定如何使用流吗? 我尝试过类似的事情:
a.filter(c -> b.anyMatch(d -> d.getUrl().equals(c.getUrl())))
但是我不知道用它来创建带有Pair
和c
的{{1}}。
答案 0 :(得分:2)
请勿使用流作为输入。流不是您数据的持有人。而是将它们用作处理数据的手段。
要考虑的另一点是,流不是Iterable
,您将无法对其进行迭代。 Collection接口是Iterable
的子类型,并且具有stream
方法,因此它提供迭代和流访问。因此,对于公共方法,Collection或适当的子类型通常是最好的返回/输入类型。
首先使用文件夹创建一个地图,其中key是url,值是folderDto。然后为每个文档查找地图以获取匹配的文件夹实例,然后创建对。我使用Map.Entry
来代替Pair
。如果您更喜欢Pair
,则可以只替换它。
这是它的外观。
private List<Entry<DocumentDto, FolderDto>> findMatchingValuesInStream(Collection<DocumentDto> a, Collection<FolderDto> b) {
Map<String, FolderDto> folderByUrl = b.stream()
.collect(Collectors.toMap(FolderDto::getUrl, Function.identity()));
return a.stream()
.map(d -> new AbstractMap.SimpleEntry<>(d, folderByUrl.get(d.getUrl())))
.collect(Collectors.toList());
}