總結一下關於在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處理數據,這時執行耗時比for循環更多,隻有業務量達到百萬級別才體現出優勢。
到此這篇關於總結一下關於在Java8中使用stream流踩過的一些坑的文章就介紹到這瞭,更多相關Java8的stream流內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java8中Stream的一些神操作
- 基於Java8並行流(parallelStream)的註意點
- Java8 中的ParallelStreams
- java8 實現提取集合對象的每個屬性
- 一篇文章帶你瞭解Java Stream流