總結(jié)一下關(guān)于在Java8中使用stream流踩過的一些坑
Java8的stream流
第一個坑:
Collectors.toAsList()其實是new了一個list,在向里面賦值。

注意這里Collectors.toList()的寫法,這里其實是底層new ArraryList().篩選的數(shù)據(jù)放到一個新的list。雖然標(biāo)1處和標(biāo)2處是同一個變量,但是內(nèi)存地址是不一樣啊。下面的邏輯時把hldrPolVOList中的某些元素刪除。但是這個方法執(zhí)行完后其實是沒有刪除里面元素的。原因就是這里的new ArraryList()更改了內(nèi)存地址造成的。
測試:

解決辦法:

第二個坑:
list.stream().foreach(p->{return;});這里的return是結(jié)束的foreach而不是外部方法

解決辦法:把stream改成for循環(huán)。
第三個坑:
并行流(parallelStream() )的foreach操作里,如果把一個ArrayList里的值copy到另外一ArrayList時,就有可能多或者少元素。原因并行流是多線程,而ArrayList是非線程安全的。
寫在最后
關(guān)于java8的stream是非常好用的,主要寫的代碼更加簡潔,不在寫大量代碼。但是也不是所有場景都適合用的,如果本來業(yè)務(wù)耗時比較長,然后有希望減少業(yè)務(wù)執(zhí)行時間。在數(shù)據(jù)量不是很大的情況下,stream流是沒有優(yōu)勢的,也就是說數(shù)據(jù)量小,且同意業(yè)務(wù)內(nèi)多處使用stream處理數(shù)據(jù),這時執(zhí)行耗時比for循環(huán)更多,只有業(yè)務(wù)量達到百萬級別才體現(xiàn)出優(yōu)勢。
到此這篇關(guān)于總結(jié)一下關(guān)于在Java8中使用stream流踩過的一些坑的文章就介紹到這了,更多相關(guān)Java8的stream流內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Boot動態(tài)加載Jar包與動態(tài)配置實現(xiàn)
隨著項目的不斷演進和業(yè)務(wù)需求的增長,很多場景下需要實現(xiàn)系統(tǒng)的動態(tài)性和靈活性,本文主要介紹了Spring Boot動態(tài)加載Jar包與動態(tài)配置實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-02-02
spring中FactoryBean中的getObject()方法實例解析
這篇文章主要介紹了spring中FactoryBean中的getObject()方法實例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-02-02
SpringCloud?服務(wù)注冊中的nacos實現(xiàn)過程
這篇文章主要介紹了SpringCloud?服務(wù)注冊之nacos實現(xiàn)過程,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
解讀file.exists(),file.isFile()和file.isDirectory()的區(qū)別
本文介紹了Java中的File類的三個方法:file.exists()、file.isFile()和file.isDirectory(),并詳細(xì)解釋了它們的區(qū)別和使用場景2025-02-02

