关于java8中使用stream流踩过的坑

java8新增了stream流式处理,对于list的各种操作处理提供了好多方法 ,用过的都知道,方便极了。比如筛选、排序、合并、类型转换等等。以下是我实际工作中踩过的坑,记录下避免大家踩坑。

第一个坑: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处理数据,这时执行耗时比for循环更多,只有业务量达到百万级别才体现出优势。

猜你喜欢

转载自blog.csdn.net/dhklsl/article/details/117918739