摘要:起因業(yè)務(wù)中需要將一組數(shù)據(jù)分類后收集總和,原本可以使用,但是我們的數(shù)據(jù)源是類型的,而原生只提供了三種基礎(chǔ)類型的方法。于是就自己動(dòng)手豐衣足食吧。。期望目標(biāo)實(shí)踐依葫蘆先分析一下方法該方法接受類型的參數(shù),返回類型的實(shí)例化對象。
起因
業(yè)務(wù)中需要將一組數(shù)據(jù)分類后收集總和,原本可以使用Collectors.summingInt(),但是我們的數(shù)據(jù)源是BigDecimal類型的,而Java8原生只提供了summingInt、summingLong、summingDouble三種基礎(chǔ)類型的方法。于是就自己動(dòng)手豐衣足食吧。。
期望目標(biāo):
Map實(shí)踐result = Arrays.stream(records).parallel().collect(Collectors.groupingBy( Record::getType, CollectorsUtil.summingBigDecimal(Record::getAmount)));
1. 依葫蘆
先分析一下Collectors.summingInt()方法
public staticCollector summingInt(ToIntFunction super T> mapper) { return new CollectorImpl<>( () -> new int[1], (a, t) -> { a[0] += mapper.applyAsInt(t); }, (a, b) -> { a[0] += b[0]; return a; }, a -> a[0], CH_NOID); }
該方法接受ToIntFunction super T>類型的參數(shù),返回CollectorImpl類型的實(shí)例化對象。CollectorImpl是Collector接口的唯一實(shí)現(xiàn)類
CollectorImpl(Supplier supplier, BiConsumer accumulator, BinaryOperator combiner, Function finisher, Setcharacteristics) { this.supplier = supplier; this.accumulator = accumulator; this.combiner = combiner; this.finisher = finisher; this.characteristics = characteristics; }
分析CollectorImpl的構(gòu)造器參數(shù),可知summingInt()方法是這樣的
arg[0]創(chuàng)建一個(gè)計(jì)算用的容器: () -> new int[1]
arg[1]為計(jì)算邏輯: (a, t) -> { a[0] += mapper.applyAsInt(t); }
arg[2]為合并邏輯: (a, b) -> { a[0] += b[0]; return a; }
arg[3]為返回最終計(jì)算值: a -> a[0]
arg[4]為空Set(不知道干什么用。。): Collections.emptySet()
2. 畫瓢
很自然的,BigDecimal的就是這樣了
public staticJava8并行流的一些tipsCollector summingBigDecimal(Function super T, BigDecimal> mapper) { return new CollectorImpl<>(() -> new BigDecimal[] { BigDecimal.ZERO }, (a, t) -> { a[0] = a[0].add(mapper.apply(t)); }, (a, b) -> { a[0] = a[0].add(b[0]); return a; }, a -> a[0], CH_NOID); }
千萬注意共享變量的使用
注意裝箱拆箱的開銷
基于數(shù)據(jù)量考慮使用并行流本身的成本
謹(jǐn)慎在并行流中使用事務(wù)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/68088.html
摘要:多級(jí)分組的為鍵,類型所對應(yīng)的集合為值一級(jí)分類為的,二級(jí)分類為的按子集收集數(shù)據(jù)的為鍵,類型所對應(yīng)的集合的為值分區(qū)分區(qū)是分組的特殊情況由一個(gè)謂詞返回一個(gè)布爾值的函數(shù)作為分類函數(shù),它稱分區(qū)函數(shù)。 收集器可以簡潔而靈活地定義collect用來生成結(jié)果集合的標(biāo)準(zhǔn)。更具體地說,對流調(diào)用 collect 方法將對流中的元素觸發(fā)一個(gè)歸約操作(由Collector來參數(shù)化)。一般來說,Collector...
摘要:收集器用作高級(jí)歸約剛剛的結(jié)論又引出了優(yōu)秀的函數(shù)式設(shè)計(jì)的另一個(gè)好處更易復(fù)合和重用。更具體地說,對流調(diào)用方法將對流中的元素觸發(fā)一個(gè)歸約操作由來參數(shù)化。另一個(gè)常見的返回單個(gè)值的歸約操作是對流中對象的一個(gè)數(shù)值字段求和。 用流收集數(shù)據(jù) 我們在前一章中學(xué)到,流可以用類似于數(shù)據(jù)庫的操作幫助你處理集合。你可以把Java 8的流看作花哨又懶惰的數(shù)據(jù)集迭代器。它們支持兩種類型的操作:中間操作(如 filt...
摘要:前置數(shù)據(jù)提取對象中的一列提取列第一種寫法簡單一點(diǎn)的寫法通過字段中條件過濾集合列表只要年紀(jì)大于歲的人列表中對象數(shù)值型列數(shù)據(jù)求和求和全部年紀(jì)取出集合符合條件的第一個(gè)元素取出年紀(jì)為歲的人簡寫對集合中對象 0x00. 前置數(shù)據(jù) private List peoples = null; @BeforeEach void before () { peoples = new ArrayL...
摘要:表達(dá)式體現(xiàn)了函數(shù)式編程的思想,即一個(gè)函數(shù)亦可以作為另一個(gè)函數(shù)參數(shù)和返回值,使用了函數(shù)作參數(shù)返回值的函數(shù)被稱為高階函數(shù)。對流對象進(jìn)行及早求值,返回值不在是一個(gè)對象。 Java8主要的改變是為集合框架增加了流的概念,提高了集合的抽象層次。相比于舊有框架直接操作數(shù)據(jù)的內(nèi)部處理方式,流+高階函數(shù)的外部處理方式對數(shù)據(jù)封裝更好。同時(shí)流的概念使得對并發(fā)編程支持更強(qiáng)。 在語法上Java8提供了Lamb...
大概一年多之前,我對java8的理解還僅限一些只言片語的文章之上,后來出于對函數(shù)式編程的興趣,買了本參考書看了一遍,然后放在了書架上,后來,當(dāng)我接手大客戶應(yīng)用的開發(fā)工作之后,java8的一些工具,對我的效率有了不小的提升,因此想記錄一下java8的一些常用場景,我希望這會(huì)成為一個(gè)小字典,能讓我免于頻繁翻書,但是總能找到自己想找的知識(shí)。 用于舉例的model: @Data public class ...
閱讀 3804·2021-09-23 11:32
閱讀 2470·2021-09-06 15:01
閱讀 1630·2021-08-18 10:24
閱讀 3468·2019-12-27 11:44
閱讀 3615·2019-08-30 15:52
閱讀 2522·2019-08-30 11:11
閱讀 696·2019-08-29 17:27
閱讀 608·2019-08-29 16:22