Stream流入门和创建方式

Java 8引入了Stream API,它提供了一种新的数据处理方式,使得集合和数组的处理更加灵活、高效。Stream API不是直接操作数据结构中的元素,而是对数据源创建一个数据流,通过声明式的方式对数据进行操作,如过滤、映射、排序等,最后再执行某个动作(例如收集结果)。

Stream的创建

Stream可以从Java的集合、数组或输入/输出通道中创建。以下是一些常见的创建Stream的方法:

  1. 从集合创建Stream

    使用集合类的stream()parallelStream()方法可以直接获取流。

    List<String> list = Arrays.asList("a", "b", "c");
    Stream<String> stream = list.stream(); // 获取顺序流
    Stream<String> parallelStream = list.parallelStream(); // 获取并行流
    
  2. 从数组创建Stream

    使用Arrays类的静态方法stream()可以将数组转换为Stream。

    String[] array = {"a", "b", "c"};
    Stream<String> streamFromArray = Arrays.stream(array);
    
  3. 使用Stream的静态工厂方法

    Stream类本身也提供了几个静态方法来创建Stream,比如of()iterate()generate()等。

    Stream<String> streamOf = Stream.of("a", "b", "c"); // 直接从元素创建
    Stream<Integer> streamIterate = Stream.iterate(0, n -> n + 1).limit(5); // 创建无限序列并限制大小
    Stream<Double> streamGenerate = Stream.generate(Math::random).limit(5); // 生成随机数流
    
  4. 从文件读取数据创建Stream

    使用Files.lines()方法可以从文本文件中读取每一行内容作为字符串流。

    try (Stream<String> lines = Files.lines(Paths.get("path/to/file.txt"))) {
        // 处理lines
    } catch (IOException e) {
        e.printStackTrace();
    }
    
  5. 从 BufferedReader 创建Stream

    如果你已经有了一个BufferedReader对象,也可以通过其行读取能力创建Stream。

    BufferedReader reader = new BufferedReader(new FileReader("file.txt"));
    Stream<String> lines = reader.lines();
    

注意事项

  • Stream操作是惰性的,即在调用最终操作(如collect(), forEach(), toArray()等)之前,中间操作(如filter(), map())不会执行。
  • Stream可以是无界(无限)的,如由iterate()generate()产生的,但在实际操作时通常需要通过limit()等方法限制其大小,以避免无限循环。
  • 并行Stream(parallelStream())可以利用多核处理器的优势,对于大数据量的操作可能更高效,但并非所有场景都适合并行处理,需根据具体情况进行选择。

掌握Stream的创建是学习和使用Java 8 Stream API的基础,通过灵活运用不同的创建方式,可以高效地处理各种数据集合。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值