Set和List集合中contains()方法执行效率问题

Set和List集合中contains()方法执行效率问题

Set检索元素效率低下,删除和插入效率高;
List查找元素效率高,插入删除元素效率低。

List虽然用get(index)方法查询效率高,但是若用contains方法查询对象元素,Set集合比List效率更高,我们证明出了,Set()的时间复杂度是O(1),而List.contain的时间复杂度是O(n)。

List<Long> searchAttrIds = attrService.selectSearchAttrIds(attrIds);
//Set集合判断包含时间复杂度为o1
Set<Long> setAttrIds = new HashSet<>(searchAttrIds);

//从商品属性关系表中拿到所有的可以被检索的属性数据,并提取出商品需要的attrs
List<SkuEsModel.Attrs> attrsList = attrsBySpuId.stream()
        .filter(item -> setAttrIds.contains(item.getAttrId()))
        .map(item -> {
            SkuEsModel.Attrs attrs = new SkuEsModel.Attrs();
            BeanUtils.copyProperties(item, attrs);
            return attrs;
        }).collect(Collectors.toList());

总结:

在判断集合中是否包含某个元素时 ,如果集合是List,就通过Set的构造方法转为Set集合进行判断

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值