加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 站长资讯 > 外闻 > 正文

何时使用Java Stream

发布时间:2021-04-19 09:34:39 所属栏目:外闻 来源:互联网
导读:的Stream API 提供了不少可替代Java 集合框架的操作。但是不少同学在学习和使用Stream时依然感到很困惑,不知道何时使用Stream,甚至想不起来使用Stream,甚至在Stream和集合框架的选择上也成了问题。今天胖哥将尝试帮你解决这些疑问。 本文已经假设你入门过

的Stream API 提供了不少可替代Java 集合框架的操作。但是不少同学在学习和使用Stream时依然感到很困惑,不知道何时使用Stream,甚至想不起来使用Stream,甚至在Stream和集合框架的选择上也成了问题。今天胖哥将尝试帮你解决这些疑问。

本文已经假设你入门过了Stream,你也可以通过这一篇来入门学习。

Stream的特点

如果你要用好Stream,你必须搞清楚它的特点。

Stream 并非数据结构

虽然我们把Stream和以Collection为代表的集合框架类型放在一起对比,但它只是将数据源(Source)中的数据元素提取到数据操作管道,并按照定义好的规则(操作符)进行“流动”。另外Stream也绝不修改自己所封装的底层数据结构的数据。

Stream有点类似于水管网络。

无固定大小

水管网络中流动的水是没有固定大小的,甚至可以是无限的。Stream也是如此。

惰性化

Stream只有定义终止操作,比如collect(Collector)、forEach(Consumer),它才会开始执行。以下从流中筛选以h开头的字符串并不会执行。m支持并行化(parallel)操作,不需要编写额外的多线程代码,所有的操作会自动并行进行。不过大多数情况下我们都是串行执行。

我们该如何选择

对于Stream和Collection我们该如何选择呢?首先Collection的绝大部分场景Stream都可以完成,甚至更好。

看API操作

它们都提供了很多方法,如果你需要获取元素的个数,集合更加方便一些,如果你要过滤一些元素,很明显,Stream的API更加方便,甚至它提供了各种可组合的操作。

看初始化成本

对于集合,一旦定义使用需要一次性的加载入内存,如果你打算在内存中重用这些数据,使用集合就非常合适;而Stream的惰性特点,在终端操作之前不会有任何的中间操作,这意味着不会上来就初始化数据到内存,可以降低初始化成本,甚至你可以调整其执行消费元素的速率。

看结果集大小

如果最终的结果是可控的、有限的,它们两者都能够胜任;如果结果集非常庞大或者近似无限的,Stream将是不二之选。

是否改变原始数据

Stream不会改变原始的数据,而Collection可以实现这一点。

是要数据容器还是数据管道。

是否需要重用对象实例

当结果以Collection的形式返回时,我们可以重复使用。而一个Stream被使用后,就认为它已消耗掉,并在重用时抛出IllegalStateException,如上面所示。

是否需要固定的格式

Stream流的表现格式通常没有Java集合框架丰富,Java集合框架提供了如Set、List、Map等格式。如果你需要终端返回展现,显然集合框架更加合适。

在Spring MVC中,Stream的展现为数组。

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读