总结一下关于在Java8中使用stream流踩过的一些坑

网友投稿 243 2023-01-03

总结一下关于在Java8中使用stream流踩过的一些坑

java8的stream流

第一个坑:

Collectors.toAsList()其实是new了一个list,在向里面赋值。

注意这里Collectors.toList()的写法,这里其实是底层new ArraryList().筛选的数据放到一个新的list。虽然标1处和标2处是同一个变量,但是内存地址是不一样啊。下面的逻辑时把hldrPolVOList中的某些元素删除。但是这个方法执行完后其实是没有删除里面元素的。原因就是这里的new ArraryList()更改了内存地址造成的。

测试:

解决办法:

第二个坑:

list.stream().foreach(p->{return;});这里的return是结束的foreach而不是外部方法

解决办法:把stream改成for循环。

第三个坑:

并行流(parallelStream() )的foreach操作里,如果把一个ArrayList里的值copy到另外一ArrayList时,就有可能多或者少元素。原因并行流是多线程,而ArrayList是非线程安全的。

写在最后

关于java8的stream是非常好用的,主要写的代码更加简洁,不在写大量代码。但是也不是所有场景都适合用的,如果本来业务耗时比较长,然后有希望减少业务执行时间。在数据量不是很大的情况下,stream流是没有优势的,也就是说数据量小,且同意业务内多处使用stream处理数据,这时执行耗时比fornOLYcdOK循环更多,只有业务量达到百万级别才体现出优势。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:如何访问网站的api接口(如何访问网站的api接口地址)
下一篇:教你快速搭建sona服务及idea使用sona的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~