Java流式编程

一、流的基础概念

  1. 流(Stream)

    • 定义:流是一种可以在数据集合上进行操作的抽象化序列,它没有存储数据的能力,而是通过一系列的操作来处理数据。
    • 特性
      • 无存储:流不存储数据,只是数据的"视图"。
      • 函数式编程:流的操作采用函数式编程风格。
      • 惰性求值:中间操作是惰性求值的,直到遇到终端操作才会真正执行。
      • 链式操作:流的中间操作可以链式调用,形成处理管道。
  2. 流的类型

    • 顺序流:按顺序处理数据。
    • 并行流:利用多核处理器并行处理数据。

二、流的创建

流可以从多种数据源创建,常见的方法有:

  1. 从集合创建流

    复制代码
    List<String> list = Arrays.asList("apple", "banana", "cherry");
    Stream<String> stream = list.stream();
  2. 从数组创建流

    复制代码
    String[] array = {"apple", "banana", "cherry"};
    Stream<String> stream = Arrays.stream(array);
  3. 使用 Stream.of() 方法

    复制代码
    Stream<String> stream = Stream.of("apple", "banana", "cherry");
  4. 生成无限流

    复制代码
    Stream<Integer> infiniteStream = Stream.iterate(0, n -> n + 2); // 生成一个无限递增的流

三、流的操作

流操作分为两类:中间操作和终端操作。

  1. 中间操作:返回一个新的流,不会立刻执行,主要用于处理数据。常见的中间操作有:

    • 过滤(Filter)

      复制代码
      Stream<String> filteredStream = stream.filter(s -> s.startsWith("a"));
    • 映射(Map)

      复制代码
      Stream<String> upperCaseStream = stream.map(String::toUpperCase);
    • 排序(Sorted)

      复制代码
      Stream<String> sortedStream = stream.sorted();
  2. 终端操作:触发流的计算并生成结果。常见的终端操作有:

    • 遍历(ForEach)

      复制代码
      stream.forEach(System.out::println);
    • 收集(Collect)

      复制代码
      List<String> resultList = stream.collect(Collectors.toList());
    • 计数(Count)

      复制代码
      long count = stream.count();

四、流式编程的示例

下面是一个示例,展示了如何使用流来处理一个字符串列表,进行过滤、映射、排序,并最终收集结果:

复制代码
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class StreamExample {
    public static void main(String[] args) {
        // 创建一个包含字符串的列表
        List<String> fruits = Arrays.asList("apple", "banana", "cherry", "date", "fig", "grape");

        // 创建流并进行一系列处理操作
        List<String> result = fruits.stream()
                                    .filter(fruit -> fruit.length() > 4) // 过滤长度大于4的水果
                                    .map(String::toUpperCase)           // 将所有水果名称转换为大写
                                    .sorted()                           // 对结果进行排序
                                    .collect(Collectors.toList());      // 收集结果到列表中

        // 打印结果
        System.out.println(result); // 输出: [BANANA, CHERRY]
    }
}

五、流的性能考虑

  1. 惰性求值:中间操作是惰性求值的,只有在遇到终端操作时才会执行。因此,可以将多个中间操作链式组合,避免不必要的计算。

  2. 并行流 :通过 parallelStream() 方法可以创建并行流,利用多核处理器提高性能。但并行流的性能提升依赖于数据集的大小和操作的复杂性,使用时需要评估性能开销。

    复制代码
    List<String> result = fruits.parallelStream()
                                .filter(fruit -> fruit.length() > 4)
                                .map(String::toUpperCase)
                                .sorted()
                                .collect(Collectors.toList());

六、总结

Java 流式编程通过简洁的 API 提供了高效、可读性强的数据处理方式。理解流的创建、操作和性能特点,能够帮助开发者更好地利用流式编程解决实际问题。

相关推荐
仙俊红2 分钟前
Spring Boot `@Configuration` 与 `@Component` 笔记
java·spring boot·笔记
小清兔2 小时前
c#基础知识
开发语言·数据库·学习·unity·c#·游戏引擎·.net
计算机学姐3 小时前
基于SpringBoot的社团管理系统【2026最新】
java·vue.js·spring boot·后端·mysql·spring·mybatis
天上掉下来个程小白3 小时前
微服务-25.网关登录校验-网关传递用户到微服务
java·数据库·微服务
奇某人4 小时前
【语法】【C+V】本身常用图表类型用法快查【CSDN不支持,VSCODE可用】
开发语言·vscode·markdown·mermaid
做一位快乐的码农4 小时前
php程序设计之基于PHP的手工艺品销售网站/基于php在线销售系统/基于php在线购物商城系统
开发语言·php
vivi_and_qiao4 小时前
HTML的form表单
java·前端·html
@珍惜一生@4 小时前
Qt开源库
开发语言·qt·开源
Slaughter信仰5 小时前
深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第四章知识点问答补充及重新排版
java·开发语言·jvm
心灵宝贝5 小时前
Mac用户安装JDK 22完整流程(Intel版dmg文件安装指南附安装包下载)
java·开发语言·macos