关注公众号“AI码师”领取2021最新面试资料一份,公众号内回复“源码”,获取本项目源码
最近在项目上面经常使用lambada表达式,但是总是记不住,一直都在百度,写完之后就忘记了,感觉很费时间;这次就花点时间,把一些常用的lambada 处理集合的实例都保存了下来(去重,分组,求和,list转map等等),以后就不用到处找了,刚好也可以给同学们分享下;另外也把一些关于使用lambada时遇到的坑也给大家一起分享下,所有代码拿来即用!!!本文档持续更新...
商品实体
@Data
@AllArgsConstructor
public class GoodInfo {
private String mallSource;
private String skuNo;
private int price;
private int monthCount;
}
集合排序在项目中用的频率还蛮高,这里以按照销量排序为例
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 按照销量正序 从小到大排序
goodInfos.sort(Comparator.comparing(GoodInfo::getMonthCount));
// 按照销量倒序 从大到小排序
goodInfos.sort(Comparator.comparing(GoodInfo::getMonthCount).reversed());
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 获取最大销量 注意如果求最大值是在filter之后使用例如,goodInfos.stream().filter().max一定要判断filter后集合数量是否不为空,否则使用max的get方法会报错
GoodInfo hotGoodInfo = goodInfos.stream().max(Comparator.comparing(GoodInfo::getMonthCount)).get();
// 求最低价格商品
GoodInfo lowPriceGoodInfo = goodInfos.stream().min(Comparator.comparing(GoodInfo::getMonthCount)).get();
// 计算商品总价格
int sum = goodInfos.stream().mapToInt(person -> person.getPrice()).sum();
// 求平均价格
double avg = goodInfos.stream().mapToInt(person -> person.getPrice()).average().getAsDouble();
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 遍历输出所有商品id
goodInfos.forEach(
goodInfo -> {
System.out.println(goodInfo.getSkuNo());
});
往往在我们项目中会有这样的需求:我需要提取集合中某一个属性,然后组装成集合,通常做法是先创建一个字符串集合,然后遍历原始集合,取出数据,放到字符串集合中,虽然也能实现功能,但是不免太过于繁琐,现在使用一行lambada表达式即可搞定:
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 将list转为某个属性map 这里是把所有skuno全部取出来 作为集合
List<String> skuNos = goodInfos.stream().map(goodInfo -> goodInfo.getSkuNo()).collect(Collectors.toList());
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 将list转为map,key 为商品id
Map<String, GoodInfo> map = goodInfos.stream().collect(Collectors.toMap(GoodInfo::getSkuNo, goodInfo -> goodInfo));
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 按照商品来源分组
Map<String, List<GoodInfo>> map = goodInfos.stream().collect(Collectors.groupingBy(GoodInfo::getMallSource));
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 过滤商品价格大于300的
// todo 过滤后一定要使用集合接收,否则等于没有过滤
List<GoodInfo> collect =
goodInfos.stream()
.filter(goodInfo -> goodInfo.getPrice() > 300)
.collect(Collectors.toList());
collect.forEach(
goodInfo -> {
System.out.println(goodInfo.getPrice());
});
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 使用treeset 集合来实现去重,这里一定要使用集合接收,不然等于没有去重
List<GoodInfo> goodInfos1 =
goodInfos.stream()
.collect(
Collectors.collectingAndThen(
Collectors.toCollection(
() -> new TreeSet<>(Comparator.comparing(o -> o.getSkuNo()))),
ArrayList::new));
public static void main(String[] args) {
List<GoodInfo> goodInfos = Arrays.asList();
goodInfos.add(new GoodInfo("tb", "tb_1112312312", 199, 100000));
goodInfos.add(new GoodInfo("tb", "tb_23534231231", 399, 10));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_1110080098", 299, 100));
goodInfos.add(new GoodInfo("jd", "jd_412313123", 99, 10000000));
goodInfos.add(new GoodInfo("pdd", "pdd_354532431", 599, 1));
goodInfos.add(new GoodInfo("pdd", "pdd_1423124131", 499, 10));
// 使用map去重
List<GoodInfo> goodInfos2 =
goodInfos.stream()
.filter(distinctByKey(goodInfo -> goodInfo.getSkuNo()))
.collect(Collectors.toList());
}
public static <T> Predicate<T> distinctByKey(Function<? super T, ?> keyExtractor) {
Map<Object, Boolean> seen = new ConcurrentHashMap<>();
return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null;
}
Optional<User> optional = goodInfos.stream().max(userComparator);
if(optional != null && optional.isPresent()) {
recentUserServer = optional.get().getServer();
}
调用filter之后,它是有返回值的,所以你需要使用新的集合去接收
。。。
后续慢慢填坑
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。