JDK12的新特性:teeing collectors
文章目錄
- 簡介
- talk is cheap, show me the code
- Teeing方法深度剖析
- Characteristics
- 總結(jié)
JDK12的新特性:teeing collectors
簡介
JDK12為java.util.stream.Collectors添加了一個新的teeing方法,怎么翻譯呢?看到很多人都把它翻譯成“發(fā)球臺”,我不禁潸然淚下,哪里有那么復(fù)雜,tee就是T。它的作用就像是一個T型,數(shù)據(jù)從兩頭進入,然后從一頭流出。teeing的作用也就在此。
更多內(nèi)容請訪問www.flydean.com
喜歡的小伙伴可以點個關(guān)注謝謝!
talk is cheap, show me the code
我最喜歡的就是一言不合上代碼,文字的描述總是讓人有點摸不著頭腦,程序員還是要用程序說話。有了程序就有了邏輯,有了邏輯一切都有了。
各大網(wǎng)站上的例子都喜歡舉maxBy和minBy的例子,我這里偏不,下面舉一個統(tǒng)計學(xué)生平均分?jǐn)?shù)和總分?jǐn)?shù)的例子,希望大家能夠喜歡:
@Testpublic void useTeeing(){List<Student> studentList= Arrays.asList(new Student("alice", 90),new Student("boy", 20),new Student("bruce", 40),new Student("batman", 100));String teeingResult=studentList.stream().collect(Collectors.teeing(Collectors.averagingInt(Student::getScore),Collectors.summingInt(Student::getScore),(s1,s2)-> s1+ ":"+ s2));log.info(teeingResult);}好了,代碼來了,上面我構(gòu)建了一個Student的List。然后通過Collectors.teeing操作,傳入了averagingInt和summingInt,最后通過一個merge表達式生成了最后的字符串。
我們看下輸出結(jié)果:
[main] INFO com.flydean.TeeingCollector - 62.5:250Teeing方法深度剖析
作為一個有追求的程序員,不深入了解下T的本質(zhì),肯定是睡不著的。我們看下T的定義:
public static <T, R1, R2, R>Collector<T, ?, R> teeing(Collector<? super T, ?, R1> downstream1,Collector<? super T, ?, R2> downstream2,BiFunction<? super R1, ? super R2, R> merger)首先分析一下T方法的返回值,T返回一個Collector。Collector是一個Reduction operations。它將輸入的元素經(jīng)過累計之后轉(zhuǎn)換成為一個結(jié)果集合。
我們再看一下Collector接口的定義:
public interface Collector<T, A, R>Collector定義了三個參數(shù)類型,T是輸入元素的類型,A是reduction operation的累加類型也就是Supplier的初始類型,R是最終的返回類型。 我們畫個圖來看一下這些類型之間的轉(zhuǎn)換關(guān)系:
Stream中的A和Supplier中的A經(jīng)過accumulator和combiner,最終在finisher中轉(zhuǎn)換成R。
T方法需要傳入兩個downstream,這兩個downstream是兩個Collector,可以看到兩者的返回類型是可以不同的。
最后一個merger將R1和R2兩種類型轉(zhuǎn)換成了最終的返回類型R。
Characteristics
最后講一下Characteristics,Characteristics是指Collector的特征。
Characteristics是為了更好的執(zhí)行collector的reduce操作。
比如,如果Characteristics是UNORDERED,則表示Collector在處理過程中并不保存元素的順序,是沒有順序的。
如果Characteristics是CONCURRENT,則表示Collector會處理多線程的問題,而不需要Stream API來考慮。
因為T方法的前面兩個參數(shù)是Collector,并且最后也返回一個Collector。
那么如果downstream1和downstream2都是UNORDERED,T最后返回的Collector也是UNORDERED的。
如果downstream1和downstream2都是CONCURRENT,T最后返回的Collector也是CONCURRENT的。
總結(jié)
上面就是T的所有介紹了。
本文的例子https://github.com/ddean2009/learn-java-base-9-to-20
更多精彩內(nèi)容且看:
- 區(qū)塊鏈從入門到放棄系列教程-涵蓋密碼學(xué),超級賬本,以太坊,Libra,比特幣等持續(xù)更新
- Spring Boot 2.X系列教程:七天從無到有掌握Spring Boot-持續(xù)更新
- Spring 5.X系列教程:滿足你對Spring5的一切想象-持續(xù)更新
- java程序員從小工到專家成神之路(2020版)-持續(xù)更新中,附詳細(xì)文章教程
本文作者:flydean程序那些事
本文鏈接:http://www.flydean.com/jdk12-teeing-collectors/
本文來源:flydean的博客
歡迎關(guān)注我的公眾號:程序那些事,更多精彩等著您!
超強干貨來襲 云風(fēng)專訪:近40年碼齡,通宵達旦的技術(shù)人生總結(jié)
以上是生活随笔為你收集整理的JDK12的新特性:teeing collectors的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JDK13的新特性:AppCDS详解
- 下一篇: JDK12的新特性:CompactNum