值匹配时推荐使用Set的Contains方法

复制代码
        List<Long> searchAttrIds = attrService.selectSearchAttrIds(attrIds);
        //转为Set,使用set的contains进行匹配性能更好
        Set<Long> idSet = new HashSet<>(searchAttrIds);
        List<SkuEsModel.Attrs> attrsList = baseAttrs.stream().filter(item -> {
            return idSet.contains(item.getAttrId());
        }).map(item -> {
            SkuEsModel.Attrs attrs1 = new SkuEsModel.Attrs();
            BeanUtils.copyProperties(item, attrs1);
            return attrs1;
        }).collect(Collectors.toList());
复制代码

总结:HashSet为哈希表计算索引,而list为链表遍历。

使用contains方法查询元素是否存在HashSet要比ArrayList快的多。

posted @   佳沃  阅读(462)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 我与微信审核的“相爱相杀”看个人小程序副业
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· spring官宣接入deepseek,真的太香了~
点击右上角即可分享
微信分享提示