快速理解和使用stream流
数据量越大,硬件内核数越多,stream流相比传统for循环速度越快。
原因是stream流是可以并行处理的。
如果要使用stream流,可以直接用flatmap把外层嵌套扁平化,只留下自己需要处理的元素
示例:
点击查看代码
List<List<Integer>> nestedList = Arrays.asList(
Arrays.asList(1, 2, 3),
Arrays.asList(4, 5, 6),
Arrays.asList(7, 8, 9)
);
List<Integer> resultList = nestedList.stream()
.flatMap(List::stream) // 将外层列表展平
.filter(num -> num % 2 == 0) // sort,forEach,filter,reduce等
.collect(Collectors.toList()); // 将处理后的元素收集到列表中
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战