Java 8 引入了 Stream,位于 java.util.stream
包中。Stream 是对象序列,类似于数组或集合,支持多种方法和聚合操作,包括过滤 (Filter)、映射 (Map)、归约 (Reduce)、限制 (Limit)、匹配 (Match) 和查找 (Find)。 这些操作不会修改原始数据源,而是创建新的 Stream 进行处理。Stream 主要分为顺序流 (Sequential Stream) 和并行流 (Parallel Stream) 两种。本文将重点阐述两者间的差异。
顺序流使用单个线程处理流水线中的数据。顺序流中的对象位于同一处理系统,并按顺序排列,因此不会利用多核系统进行处理。
并行流利用多核处理器来提高程序性能。代码通过并行流方法被分割成多个流,这些流在不同的内核上并行执行。最终结果合并后显示。由于执行不受开发人员控制,结果可能无序。并行流可以通过以下方式使用:
Collection
接口包含 parallelStream()
方法,用于创建并行流。BaseStream
接口包含 parallel()
方法,可用于将顺序流转换为并行流。下表总结了 Java 中顺序流和并行流的主要区别:
顺序流 | 并行流 |
---|---|
在计算机的单个内核上执行。 | 在计算机的多个内核上执行。 |
性能较慢。 | 性能较快。 |
执行过程中保持顺序。 | 执行过程中不保证顺序。 |
一次只能进行单个迭代。 | 由于在多个内核上执行,可以进行多个迭代。 |
每个迭代必须等待前一个迭代完成才能执行。 | 如果所有内核都繁忙,则流必须等待;否则,它们将同时执行而无需等待。 |
出错概率较低。 | 出错概率较高。 |
与平台无关。 | 依赖于平台。 |
Java 中的 Stream 主要分为顺序流和并行流两种。顺序流按顺序执行对象操作,结果有序,使用计算机的单个内核执行,性能较慢,但与平台无关。并行流使用计算机的多个内核执行,性能很快,但结果无序。
顺序流与平台无关,因为它只使用单个内核执行代码。并行流使用多个内核执行代码,因此依赖于平台。
并行流更容易出错,因为它在计算机的多个内核上运行,结果无序。顺序流出错概率较低,因为它只使用单个内核执行代码。
在顺序流中,一次只能进行一个迭代。下一个迭代必须等待当前迭代执行完成。在并行流中,迭代在不同的内核上同时工作。如果所有内核都繁忙,则迭代必须等待。
顺序流在执行过程中保持顺序,因为它只使用一个内核,并且每个迭代必须等待当前迭代完成执行。
并行流的性能更快,因为它使用多个内核执行。顺序流只使用一个内核,因此性能较慢。
以上是Java中的平行和顺序流之间的差异的详细内容。更多信息请关注PHP中文网其他相关文章!