Java流:声明数据处理
Java流提供了一种处理数据集的声明方法。它们简化了数据集的操作,无需显式管理迭代器或索引。
集合与流的差异:
- 集合: 可修改存储数据元素。
- 流: 原始数据不能修改处理数据元素的序列,数据处理完成后会被销毁(消耗)。
流的优势:
立即学习“Java免费学习笔记(深入);
- 代码简洁: 避免冗长的循环和迭代代码。
- 不变性: 原始数据保持不变。
- 并行处理: 支持并行处理,提高性能。
流操作类型:
流操作主要分为三种:
- 初始操作 (流创建): 创建流量来自数据源(如列表、数组或单个值)。这是必要的操作。
- 中间操作: 转换流,产生新的流,但不会消耗原始流。这些操作是惰性的,只有在最终操作被调用时才能执行。
- 最终操作: 处理流元素,结束流的使用。最终操作后,流不能再次使用。
示例:
1. 只有初始操作和最终操作 (无中间操作):
List<String> names = List.of("Ana", "Bruno", "Carlos"); names.stream().forEach(System.out::println); // 最终操作
2. 初始操作、中间操作和最终操作:
List<String> names = List.of("Ana", "Bruno", "Carlos"); names.stream() .filter(name -> name.startsWith("B")) // 中间操作 .forEach(System.out::println); // 最终操作
3. 只有初始操作和中间操作 (无效!):
List<String> names = List.of("Ana", "Bruno", "Carlos"); names.stream().filter(name -> name.startsWith("B")); // 不会产生任何输出
总结:
流程处理流程:创建流程 -> (可选) 中间操作 -> 最终操作
创建流:
-
从列表: List
names = List.of("Ana", "Bruno", "Carlos"); Stream namesStream = names.stream(); -
从数组: String[] array = {"a", "b", "c"}; Stream
arrayStream = Arrays.stream(array); -
从值: Stream
valuesStream = Stream.of("java", "python", "c"); -
无限流 (generate): Stream
random = Stream.generate(Math::random); (需要limit()限制元素数量) -
无限流 (iterate): Stream
numbers = Stream.iterate(0, n -> n + 2); (需要limit()限制元素数量)
中间操作:
中间操作返回新流,允许链式调用:
- map(): 转换元素。
- filter(): 过滤元素。
- sorted(): 排序元素。
- distinct(): 去除重复元素。
- limit(): 限制元素数量。
- skip(): 跳过指定数量的元素。
最终操作:
最终操作处理数据并结束流:
- forEach(): 迭代元素。
- count(): 统计元素数量。
- collect(): 在集合中收集元素。
- reduce(): 将元素归约为单个值。
示例:
List<String> names = List.of("Ana", "Bruno", "Carlos"); List<String> filteredNames = names.stream() .filter(name -> name.startsWith("B")) .collect(Collectors.toList()); long count = names.stream().count(); int sum = List.of(1, 2, 3, 4, 5).stream().reduce(0, Integer::sum);
以上是溪流EM 更多关于Java的详细信息,请关注图灵教育的其他相关文章!