posts - 101,comments - 5,views - 14万
复制代码

package com.fql.lamda.Lamda;


import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;


import javax.swing.plaf.synth.SynthSeparatorUI;


import com.fql.entity.Foo;


/*
*Collectors.groupingBy(a,Function)
* a:被groupby的字段; fucntion:聚合后得到结果,比如fucntion是Collectors.toList()是聚合后转为list,是Collectors.counting是聚合后count值
*
*/


public class LamdaGroupBy {
public static void main(String[] args) {
List<Foo> fooList = Arrays.asList(
new Foo("A","san",99.0,2),
new Foo("A","nas",613.0,1),
new Foo("B","san",112.0,3),
new Foo("C","san",43.0,5),
new Foo("B","nas",77.0,7)
);
//1. groupby(a,Collectors.toList()) 聚合后转化为Map<Object,List<>)
Map<Object,List<Foo>>listMap=fooList.stream().collect(Collectors.groupingBy(f->f.getName(),Collectors.toList()));
listMap.entrySet().forEach(lk->{
List<Foo> listT=lk.getValue();
listT.sort((l1,l2)->l1.getScore().compareTo(l2.getScore()));  //将每个key对应valueList内容按照score进行排序
System.out.println("mapList_Name:"+lk.getValue().get(0).getName()+"mapList_score:"+lk.getValue().get(0).getScore());
});
System.out.println("end 1...");
//2.
Map<String,Long> mapCount=fooList.stream().collect(Collectors.groupingBy(f->f.getGrade(),Collectors.counting()));
mapCount.entrySet().stream().forEach(m->{
System.out.println("key:"+m.getKey());
System.out.println("value:"+m.getValue());
});
System.out.println("end 2...");
}


}

 
复制代码

运行结果:

mapList_Name:nas mapList_score:77.0
mapList_Name:san mapList_score:43.0
end 1...
key:A
value:2
key:B
value:2
key:C
value:1
end 2...

posted on   colorfulworld  阅读(322)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2019-06-07 redis分布式锁
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示