栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用Java 8 Stream在2个列表中查找匹配的元素

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用Java 8 Stream在2个列表中查找匹配的元素

为自己定义一个关键对象,该对象可以保存并比较所需的属性。在这种简单情况下,您可以使用一个小的列表,而每个索引对应一个属性。对于更复杂的情况,可以使用

Map
(使用属性名称作为键)或专用类:

Function<Person,List<Object>> toKey=p -> Arrays.asList(p.getName(), p.getAge());

具有这种映射功能。您可以使用简单的解决方案:

list1.stream().map(toKey)     .flatMap(key -> list2.stream().map(toKey).filter(key::equals))     .forEach(key -> System.out.println("{name="+key.get(0)+", age="+key.get(1)+"}"));

当您的列表很大时,这可能会导致性能不佳。如果列表很大(或者无法预测它们的大小),则应该使用中间变量

Set
来加速查找(将任务的时间复杂度从更改
O(n²)
O(n)
):

list2.stream().map(toKey)     .filter(list1.stream().map(toKey).collect(Collectors.toSet())::contains)     .forEach(key -> System.out.println("{name="+key.get(0)+", age="+key.get(1)+"}"));

在上面的示例中,每个匹配项都被打印出来。如果您仅对是否存在这样的匹配感兴趣,则可以使用以下任一方法:

boolean exists=list1.stream().map(toKey)     .anyMatch(key -> list2.stream().map(toKey).anyMatch(key::equals));

要么

boolean exists=list2.stream().map(toKey)     .anyMatch(list1.stream().map(toKey).collect(Collectors.toSet())::contains);


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/507625.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号