lamda特性,List转Map

list 分组成 map

 

Map<Integer, List<Apple>> groupBy = appleList.stream().collect(Collectors.groupingBy(Apple::getId));

list直接转成map并且key去重

需要注意的是:toMap 如果集合对象有重复的key,会报错Duplicate key ....
apple1,apple12的id都为1。
可以用 (k1,k2)->k1 来设置,如果有重复的key,则保留key1,舍弃key2

 

Map<Integer, Apple> appleMap = appleList.stream().collect(Collectors.toMap(Apple::getId, a -> a,(k1,k2)->k1))

过滤filter

 

// 过滤出符合条件的数据
List<Apple> filterList = appleList.stream().filter(a -> a.getName().equals("香蕉")).collect(Collectors.toList());

求和

 

// 计算总金额
BigDecimal totalMoney = appleList.stream().map(Apple::getMoney).reduce(BigDecimal.ZERO, BigDecimal::add);

查找流中最大 最小值

 

// Collectors.maxBy 和 Collectors.minBy 来计算流中的最大或最小值。
Optional<Dish> maxDish = Dish.menu.stream().collect(Collectors.maxBy(Comparator.comparing(Dish::getCalories))); 
Optional<Dish> minDish = Dish.menu.stream().collect(Collectors.minBy(Comparator.comparing(Dish::getCalories)));

去重

 

// 根据id去重
 List<Person> unique = appleList.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Collectors.comparingLong(Apple::getId))), ArrayList::new));

Collectors 类的静态工厂方法。

工厂方法返回类型作用
toListList<T>把流中的所有元素收集到一个List
toSetSet<T>把流中的所有元素收集到一个Set,删除重复项
toCollectionCollection<T>把流中所有元素收集到给定的容器中menuStream.collect(toCollection(), ArrayList::new)
countingLong计算流中的元素个数
sumIntInteger对流中的一个整数进行求和
averaginDouble计算流中integer属性的平均值
summarizingIntIntSummaryStatistics收集关于流中 Integer 属性的统计值,例如最大、最小、 总和与平均值
joiningString连接对流中每个元素调用 toString 方法所生成字符串collect(joining(", "))
maxByOptoinal<T>一个包裹了流中按照给定比较器选出的最大元素的 Optional, 或如果流为空则为 Optional.empty()
minByOptional<T>一个包裹了流中按照给定比较器选出的最小元素的 Optional, 或如果流为空则为 Optional.empty()
reducing 从一个作为累加器的初始值开始,利用 BinaryOperator 与流 中的元素逐个结合,从而将流归约为单个值累加int totalCalories = menuStream.collect(reducing(0, Dish::getCalories, Integer::sum));
collectingAndThen 包裹另一个收集器,对其结果应用转换函数int howManyDishes = menuStream.collect(collectingAndThen(toList(), List::size))
groupingByMap<K, List<T>>根据项目的一个属性的值对流中的项目作问组,并将属性值作 为结果 Map 的键
partitioningByMap<Boolean,List<T>根据对流中每个项目应用谓词的结果来对项目进行分区



作者:L千年老妖
链接:https://www.jianshu.com/p/28bcf21dfd03
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值