什么是Stream流

Stream流的概念

Stream是Java 8引入的API,用于以声明式方式处理集合数据(如过滤、映射、排序等)。它允许高效、并行化的操作,无需显式编写循环代码。Stream不存储数据,而是通过操作管道(如filter、map)对数据源(集合、数组等)进行计算。

Stream流的特点

  • 惰性求值:中间操作(如filter)不会立即执行,只有终端操作(如collect)触发时才会处理数据。
  • 无存储:Stream本身不存储数据,仅代表数据源的视图。
  • 函数式风格:支持链式调用,代码更简洁。
  • 可并行化 :通过parallel()方法轻松实现并行处理。

常用操作示例

创建Stream
java 复制代码
List<String> list = Arrays.asList("a", "b", "c");
Stream<String> stream = list.stream(); // 从集合创建
Stream<Integer> nums = Stream.of(1, 2, 3); // 直接生成
中间操作
java 复制代码
stream.filter(s -> s.startsWith("a")) // 过滤
      .map(String::toUpperCase)       // 映射
      .sorted();                      // 排序
终端操作
java 复制代码
long count = stream.count(); // 计数
List<String> result = stream.collect(Collectors.toList()); // 收集为List
stream.forEach(System.out::println); // 遍历

并行流

通过parallelStream()parallel()方法启用并行处理:

java 复制代码
list.parallelStream().forEach(System.out::println); // 并行处理

注意事项

  • Stream只能被消费一次,重复使用会抛出IllegalStateException
  • 并行流需注意线程安全问题,避免共享可变状态。
相关推荐
疯狂敲代码的老刘3 小时前
JDK 1.6到25 全版本网盘合集 (Windows + Mac + Linux)
java·linux·windows·macos·jdk
love530love4 小时前
Windows 下 GCC 编译器安装与排错实录
人工智能·windows·python·gcc·msys2·gtk·msys2 mingw 64
猫头虎5 小时前
OpenClaw开源汉化发行版:介绍、下载、安装、配置教程
运维·windows·开源·aigc·ai编程·agi·csdn
luffy54595 小时前
windows下通过docker-desktop创建redis实例
windows·redis·docker·容器
程序员敲代码吗5 小时前
Windows组策略限制规避指南:深入解析与实际操作
windows
黄大帅@lz6 小时前
openai提示词学习
windows·学习
MyY_DO6 小时前
十四课 易语言核心逆向
windows·od
AI袋鼠帝17 小时前
Claude4.5+Gemini3 接管电脑桌面,这回是真无敌了..
人工智能·windows·aigc
獨枭18 小时前
Windows 下安装与使用 Miniconda 完整指南
windows
命里有定数19 小时前
保姆级教程:在 Windows (WSL2) 下本地部署 Qwen3-ASR
windows