当前位置: 首页 > news >正文

Java8 Stream流:Stream流的思想和获取Stream流

Stream流的思想

Stream流是Java 8引入的一种处理集合数据的抽象概念,其核心思想是将数据源(如集合、数组等)转化为流,通过链式调用一系列中间操作(如过滤、映射、排序等)对数据进行处理,最后通过终端操作(如收集、计数等)生成结果。Stream流强调函数式编程惰性求值,能够高效、简洁地处理数据。

获取Stream流的方法

单列集合获取Stream流

单列集合(如ListSet)可以直接调用stream()方法获取流。

List<String> list = Arrays.asList("Java", "Python", "C++");
Stream<String> stream = list.stream();

实例:

public class StreamDemo2 {public static void main(String[] args) {
/*单列集合      default Stream<E> stream()                           Collection中的默认方法双列集合      无                                                   无法直接使用stream流数组          public static <T> Stream<T> stream(T[] array)        Arrays工具类中的静态方法一堆零散数据   public static<T> Stream<T> of(T... values)           Stream接口中的静态方法
*///1.单列集合获取Stream流ArrayList<String> list = new ArrayList<>();Collections.addAll(list,"a","b","c","d","e");/*//获取到一条流水线,并把集合中的数据放到流水线上Stream<String> stream1 = list.stream();//使用终结方法打印一下流水线上的所有数据stream1.forEach(new Consumer<String>() {@Overridepublic void accept(String s) {//s:依次表示流水线上的每一个数据System.out.println(s);}});*/list.stream().forEach(s -> System.out.println(s));}
}
双列集合获取Stream流

双列集合(如Map)需先转换为单列集合(如entrySetkeySetvalues),再获取流。

Map<String, Integer> map = new HashMap<>();
map.put("A", 1);
map.put("B", 2);// 获取键的流
Stream<String> keyStream = map.keySet().stream();
// 获取值的流
Stream<Integer> valueStream = map.values().stream();
// 获取键值对的流
Stream<Map.Entry<String, Integer>> entryStream = map.entrySet().stream();

实例:

public class StreamDemo3 {public static void main(String[] args) {//双列集合      无                                                   无法直接使用stream流//1.创建双列集合HashMap<String,Integer> hm = new HashMap<>();//2.添加数据hm.put("aaa",111);hm.put("bbb",222);hm.put("ccc",333);hm.put("ddd",444);//3.第一种获取stream流//hm.keySet().stream().forEach(s -> System.out.println(s));//4.第二种获取stream流hm.entrySet().stream().forEach(s-> System.out.println(s));}
}
数组获取Stream流

通过Arrays.stream()方法或Stream.of()方法获取流。

String[] array = {"Apple", "Banana", "Orange"};// 方式1
Stream<String> stream1 = Arrays.stream(array);
// 方式2
Stream<String> stream2 = Stream.of(array);

实例:

public class StreamDemo4 {public static void main(String[] args) {// 数组          public static <T> Stream<T> stream(T[] array)        Arrays工具类中的静态方法//1.创建数组int[] arr1 = {1,2,3,4,5,6,7,8,9,10};String[] arr2 = {"a","b","c"};//2.获取stream流// Arrays.stream(arr1).forEach(s-> System.out.println(s));//System.out.println("============================");//Arrays.stream(arr2).forEach(s-> System.out.println(s));//System.out.println("============================");//注意://Stream接口中静态方法of的细节//方法的形参是一个可变参数,可以传递一堆零散的数据,也可以传递数组//但是数组必须是引用数据类型的,如果传递基本数据类型,是会把整个数组当做一个元素,放到Stream当中。Stream.of(arr1).forEach(s-> System.out.println(s));//[I@41629346}
}
零散数据获取Stream流

使用Stream.of()直接生成流。

Stream<Integer> stream = Stream.of(1, 2, 3, 4, 5);

实例:

public class StreamDemo5 {public static void main(String[] args) {//一堆零散数据   public static<T> Stream<T> of(T... values)           Stream接口中的静态方法Stream.of(1,2,3,4,5).forEach(s-> System.out.println(s));Stream.of("a","b","c","d","e").forEach(s-> System.out.println(s));}
}
其他方式
  1. 生成无限流:通过Stream.iterate()Stream.generate()

    // 从0开始,每次加2
    Stream<Integer> infiniteStream = Stream.iterate(0, n -> n + 2);
    // 生成随机数流
    Stream<Double> randomStream = Stream.generate(Math::random);
    

  2. 文件流:通过Files.lines()读取文件内容为流。

    Path path = Paths.get("file.txt");
    Stream<String> fileStream = Files.lines(path);
    

  3. 基本类型流:如IntStreamLongStreamDoubleStream

    IntStream intStream = IntStream.of(1, 2, 3);
    

示例整合

以下代码展示不同数据源如何获取Stream流并操作:

import java.util.*;
import java.util.stream.*;
import java.nio.file.*;public class StreamExample {public static void main(String[] args) {// 单列集合List<String> list = Arrays.asList("Java", "Python", "C++");list.stream().filter(s -> s.startsWith("J")).forEach(System.out::println);// 双列集合Map<String, Integer> map = Map.of("A", 1, "B", 2);map.entrySet().stream().filter(e -> e.getValue() > 1).forEach(e -> System.out.println(e.getKey()));// 数组String[] array = {"Apple", "Banana"};Arrays.stream(array).map(String::toUpperCase).forEach(System.out::println);// 零散数据Stream.of(1, 2, 3).map(n -> n * 2).forEach(System.out::println);}
}

Stream流的核心优势在于链式操作惰性执行,能够高效处理大量数据且代码可读性强。

相关文章:

  • 毕业设计网站建设选题依据优化大师下载旧版本安装
  • 怎么做软件 用手机seo课堂
  • 无锡市新吴区住房和建设交通局网站网络营销与网站推广的区别
  • 苏州外贸网站互联网下的网络营销
  • 广告艺术设计专业介绍站长之家seo工具
  • 用wex5 网站开发定制网站+域名+企业邮箱
  • 【AI】Manus自主产品原型设计
  • Python函数
  • ubuntu中53端口被占用导致dnsmasq无法使用。已解决。
  • GO 语言学习 之 运算符号
  • 自动化测试工具Katalon 之核心概念全解析
  • 浙大/浙工大合作iMeta(1区 | IF 33.2):单微生物RNA-seq + 聚类解析肠道关键种代谢功能
  • 自动化测试--App自动化之项目实战脚本编写及封装流程
  • 【MCP 实战4-1】开发 OpenSearch MCP server
  • 微信小程序中scss、ts、wxml
  • 开源代码修复新标杆——月之暗面最新开源编程模型Kimi-Dev-72B本地部署教程,自博弈修复 Bug
  • Opengauss数据库的安装以及镜像源配置
  • 链表“追及”问题终极指南:快慢指针三部曲
  • 汉字编码之GBK编码详解
  • 数据结构 顺序表与链表
  • Spring Cloud Ribbon核心负载均衡算法详解
  • SDC命令详解:使用write_sdc命令进行输出
  • 高等数学》(同济大学·第7版)第七章 微分方程 第五节可降阶的高阶微分方程
  • Feign源码解析:动态代理与HTTP请求全流程
  • Azure虚拟机添加磁盘
  • 企业级RAG系统架构设计与实现指南(Java技术栈)