Java Stream 流常用操作大全

文章目录

  • [1. 逗号分隔的字符串转 List](#1. 逗号分隔的字符串转 List)
    • [(1)转 `List<String>`](#(1)转 List<String>)
    • [(2)转 `List<Long>`](#(2)转 List<Long>)
  • [2. map 元素映射](#2. map 元素映射)
  • [3. filter 元素过滤](#3. filter 元素过滤)
  • [4. findFirst 查找首个元素](#4. findFirst 查找首个元素)
    • [(1)查找 filter 过滤后的首个元素](#(1)查找 filter 过滤后的首个元素)
  • [5. groupingBy 分组](#5. groupingBy 分组)

1. 逗号分隔的字符串转 List

(1)转 List<String>

java 复制代码
String str = "1,2,3,4,5,6";
List<String> list = Arrays.stream(str.split(","))
	.map(String::trim).collect(Collectors.toList());

(2)转 List<Long>

java 复制代码
String str = "1,2,3,4,5,6";
List<Long> list = Arrays.stream(str.split(","))
	.map(s -> Long.parseLong(s.trim())).collect(Collectors.toList());

2. map 元素映射

java 复制代码
List<String> usernameList = records.stream()
		.map(SysUser::getUsername())
		.collect(Collectors.toList());

3. filter 元素过滤

java 复制代码
List<SysUser> sysUserList = records.stream()
		.filter(x -> StrUtil.equals(x.getUsername(), "taibai"))
		.collect(Collectors.toList());

4. findFirst 查找首个元素

(1)查找 filter 过滤后的首个元素

java 复制代码
SysUser sysUser = records.stream()
		.filter(x -> StrUtil.equals(x.getUsername(), "taibai"))
		.findFirst().orElse(null);

5. groupingBy 分组

(1)单个字段分组

java 复制代码
Map<String, SysUser> countMap = records.stream()
		.collect(Collectors.groupingBy(SysUser::getDeptId()));

(2)单个字段分组-统计数量

java 复制代码
Map<String, Long> countMap = records.stream()
		.collect(Collectors.groupingBy(SysUser::getDeptId(), Collectors.counting()));

(3)多字段分组

java 复制代码
Map<String, SysUser> countMap = records.stream()
		.collect(Collectors.groupingBy(x -> x.getDeptId() + "_" + x.getRoleId()));

(4)多字段分组-统计数量

java 复制代码
Map<String, Long> countMap = records.stream()
		.collect(Collectors.groupingBy(x -> x.getProductType() + "_" + x.getCountry(), Collectors.counting()));

相关推荐
谷大羽11 小时前
Kafka Stream实战教程
spring boot·后端·中间件·kafka·stream
爱吃土豆的程序员2 天前
深入理解 Java 8 Stream 之 collect()
java·stream·collectors
爱吃土豆的程序员1 个月前
java List<Map<String, Object>> 转 List<JSONObject> 的几种方式
java·list·stream·jsonobject·集合转换
营赢盈英3 个月前
using showdown js with openAi streaming response
开发语言·前端·javascript·stream·openai api
是枫似风3 个月前
消息驱动Stream---基于SpringCloud
java·spring boot·后端·spring·spring cloud·stream·消息分区
法尼的铁帽子3 个月前
stream流与Predicate结合对集合去重或获取重复元素
java·stream·java8
iFlyCai3 个月前
Flutter中的异步编程
flutter·stream·async·future·await·futurebuilder·flutter异步编程
Hello-Brand4 个月前
Redis系列:使用Stream实现消息队列 (图文总结+Go案例)
redis·stream·高性能·高可用·xadd·xread
伊织code4 个月前
python_rtmpstream - Python rtmp 推流
开发语言·python·ffmpeg·stream·推流·rtmp