總結一下關於在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!

推薦閱讀: