總結(jié)一下關(guān)于在Java8中使用stream流踩過(guò)的一些坑
Java8的stream流
第一個(gè)坑:
Collectors.toAsList()其實(shí)是new了一個(gè)list,在向里面賦值。
注意這里Collectors.toList()的寫(xiě)法,這里其實(shí)是底層new ArraryList().篩選的數(shù)據(jù)放到一個(gè)新的list。雖然標(biāo)1處和標(biāo)2處是同一個(gè)變量,但是內(nèi)存地址是不一樣啊。下面的邏輯時(shí)把hldrPolVOList中的某些元素刪除。但是這個(gè)方法執(zhí)行完后其實(shí)是沒(méi)有刪除里面元素的。原因就是這里的new ArraryList()更改了內(nèi)存地址造成的。
測(cè)試:
解決辦法:
第二個(gè)坑:
list.stream().foreach(p->{return;});這里的return是結(jié)束的foreach而不是外部方法
解決辦法:把stream改成for循環(huán)。
第三個(gè)坑:
并行流(parallelStream() )的foreach操作里,如果把一個(gè)ArrayList里的值copy到另外一ArrayList時(shí),就有可能多或者少元素。原因并行流是多線程,而ArrayList是非線程安全的。
寫(xiě)在最后
關(guān)于java8的stream是非常好用的,主要寫(xiě)的代碼更加簡(jiǎn)潔,不在寫(xiě)大量代碼。但是也不是所有場(chǎng)景都適合用的,如果本來(lái)業(yè)務(wù)耗時(shí)比較長(zhǎng),然后有希望減少業(yè)務(wù)執(zhí)行時(shí)間。在數(shù)據(jù)量不是很大的情況下,stream流是沒(méi)有優(yōu)勢(shì)的,也就是說(shuō)數(shù)據(jù)量小,且同意業(yè)務(wù)內(nèi)多處使用stream處理數(shù)據(jù),這時(shí)執(zhí)行耗時(shí)比f(wàn)or循環(huán)更多,只有業(yè)務(wù)量達(dá)到百萬(wàn)級(jí)別才體現(xiàn)出優(yōu)勢(shì)。
到此這篇關(guān)于總結(jié)一下關(guān)于在Java8中使用stream流踩過(guò)的一些坑的文章就介紹到這了,更多相關(guān)Java8的stream流內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java實(shí)現(xiàn)合并兩個(gè)已經(jīng)排序的列表實(shí)例代碼
這篇文章主要介紹了java實(shí)現(xiàn)合并兩個(gè)已經(jīng)排序的列表實(shí)例代碼,有需要的朋友可以參考一下2013-12-12一段眼睛跟著鼠標(biāo)轉(zhuǎn)動(dòng)的跟蹤眼代碼
java實(shí)現(xiàn)的眼睛跟著鼠標(biāo)轉(zhuǎn)動(dòng)的跟蹤眼代碼2008-10-10JAVA 時(shí)間區(qū)間的字符串合法性驗(yàn)證
需要對(duì)獲得的諸如08:30-11:00這樣的字符串進(jìn)行合法性驗(yàn)證,判定表示的時(shí)間區(qū)間是否合法,以及對(duì)高峰期時(shí)間的區(qū)間是否在總的時(shí)間區(qū)間內(nèi)部進(jìn)行判斷。2013-03-03Spring AOP AspectJ使用及配置過(guò)程解析
這篇文章主要介紹了Spring AOP AspectJ使用及配置過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01使用mybatis的interceptor修改執(zhí)行sql以及傳入?yún)?shù)方式
這篇文章主要介紹了使用mybatis的interceptor修改執(zhí)行sql以及傳入?yún)?shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12