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(); // 并行计算平方和

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

五、注意事项

​流的不可复用性​

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

​惰性求值​

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

​避免副作用​

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

相关推荐
Haven-1 小时前
Java-面试八股文-JVM篇
java·jvm·面试
我真的是大笨蛋1 小时前
JVM调优总结
java·jvm·数据库·redis·缓存·性能优化·系统架构
wjs0401 小时前
Git常用的命令
java·git·gitlab
superlls1 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
honder试试2 小时前
焊接自动化测试平台图像处理分析-模型训练推理
开发语言·python
^Rocky2 小时前
JavaScript性能优化实战
开发语言·javascript·性能优化
田里的水稻2 小时前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
ponnylv2 小时前
深入剖析Spring Boot启动流程
java·开发语言·spring boot·spring
萧邀人2 小时前
第一课、Cocos Creator 3.8 安装与配置
开发语言
前行的小黑炭2 小时前
Android 协程的使用:结合一个环境噪音检查功能的例子来玩玩
android·java·kotlin