Java的流表达式使用

一、流的创建

流可以从多种数据源创建,包括集合、数组、I/O资源等:

java

// 从集合创建

List list = Arrays.asList(1, 2, 3);

Stream stream = list.stream();

// 从数组创建

int[] array = {1, 2, 3};

IntStream intStream = Arrays.stream(array);

// 通过Stream.of创建

Stream stringStream = Stream.of("A", "B", "C");

二、中间操作(Intermediate Operations)

中间操作返回新流,支持链式调用,但不会立即执行:

​过滤(Filter)​​

筛选符合条件的元素:

java

list.stream().filter(n -> n % 2 == 0); // 筛选偶数

​映射(Map)​​

转换元素类型或提取属性:

java

list.stream().map(String::toUpperCase); // 字符串转大写

​排序(Sorted)​​

按自然顺序或自定义比较器排序:

java

list.stream().sorted(Comparator.reverseOrder()); // 降序排列

​去重(Distinct)​​

去除重复元素:

java

list.stream().distinct();

​截取与跳过(Limit/Skip)​​

java

list.stream().limit(5); // 取前5个元素

list.stream().skip(2); // 跳过前2个元素

三、终止操作(Terminal Operations)

终止操作触发流的执行并返回结果:

​收集结果(Collect)​​

将流转换为集合或聚合数据:

java

List names = list.stream()

.filter(s -> s.startsWith("A"))

.collect(Collectors.toList());

​遍历(ForEach)​​

对每个元素执行操作:

java

list.stream().forEach(System.out::println);

​统计(Count/Sum/Max/Min)​​

java

long count = list.stream().count(); // 元素总数

int sum = list.stream().mapToInt(Integer::intValue).sum(); // 求和

​归约(Reduce)​​

自定义聚合逻辑:

java

int sum = list.stream().reduce(0, Integer::sum); // 累加求和

四、并行流(Parallel Stream)

通过并行处理提升大数据集性能:

java

int sum = list.parallelStream()

.mapToInt(n -> n * n)

.sum(); // 并行计算平方和

注意:并行流适用于计算密集型任务,但可能因线程开销导致小数据集效率降低。

五、注意事项

​流的不可复用性​

流一旦被终止操作消费,不可重复使用。

​惰性求值​

中间操作延迟执行,直到终止操作触发。

​避免副作用​

推荐使用纯函数式操作,而非在流中修改外部变量。

相关推荐
海边的Kurisu2 小时前
苍穹外卖日记 | Day1 苍穹外卖概述、开发环境搭建、接口文档
java
C雨后彩虹5 小时前
任务最优调度
java·数据结构·算法·华为·面试
heartbeat..5 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
Jing_jing_X5 小时前
AI分析不同阶层思维 二:Spring 的事务在什么情况下会失效?
java·spring·架构·提升·薪资
SmartRadio7 小时前
CH585M+MK8000、DW1000 (UWB)+W25Q16的低功耗室内定位设计
c语言·开发语言·uwb
rfidunion7 小时前
QT5.7.0编译移植
开发语言·qt
rit84324997 小时前
MATLAB对组合巴克码抗干扰仿真的实现方案
开发语言·matlab
元Y亨H7 小时前
Nacos - 服务发现
java·微服务
微露清风7 小时前
系统性学习C++-第十八讲-封装红黑树实现myset与mymap
java·c++·学习
dasi02277 小时前
Java趣闻
java