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()));

相关推荐
云雾J视界5 天前
多Stream并发实战:用流水线技术将AIGC服务P99延迟压降63%
aigc·api·cpu·stream·gpu·cuda·多并发
颜颜yan_8 天前
基于CANN多Stream异步执行的智能推理管道:突破传统串行瓶颈
运维·架构·stream·昇腾·cann
彩虹、1 个月前
数据处理常用到的一些Java 8中Stream操作
stream·java 8
程序员三明治1 个月前
选 Redis Stream 还是传统 MQ?队列选型全攻略(适用场景、优缺点与实践建议)
java·redis·后端·缓存·rocketmq·stream·队列
花伤情犹在2 个月前
Java Stream 高级应用:优雅地扁平化(FlatMap)递归树形结构数据
java·stream·function·flatmap
sg_knight2 个月前
Spring Cloud与RabbitMQ深度集成:从入门到生产级实战
java·spring boot·spring·spring cloud·消息队列·rabbitmq·stream
DN金猿2 个月前
java8提取list中对象有相同属性值的对象或属性值
java·list·stream·java8
mask哥3 个月前
详解flink性能优化
java·大数据·微服务·性能优化·flink·kafka·stream
中草药z3 个月前
【Stream API】高效简化集合处理
java·前端·javascript·stream·parallelstream·并行流
mask哥3 个月前
详解kafka streams(二)
java·大数据·微服务·flink·kafka·stream·流式操作