欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java分析Lambda表達式Stream流合并分組內對象數據合并

 更新時間:2022年12月06日 10:40:17   作者:leo825...  
Lambda表達式,基于Lambda所帶來的函數式編程,又引入了一個全新的Stream概念,用于解決集合類庫既有的弊端,Lambda 允許把函數作為一個方法的參數(函數作為參數傳遞進方法中)。使用 Lambda 表達式可以使代碼變的更加簡潔緊湊

前言

之前寫過《Lambda使用——JDK8新特性》,現在有一個分組合并的需求正好拿來小試牛刀。

需求

數據出自許多接口數據,需要將幾個接口數據根據省份id進行分組合并。舉例說明:

A接口返回List里面有值的的字段為:provinceId、field1、field2、field3

B接口返回List里面有值的的字段為:provinceId、field4、field5、field6

C接口返回List里面有值的的字段為:provinceId、field7、field8、field9

最終實現的效果是返回一個最終的list,里面的每一個實體值是上面所有字段合并后的值(provinceId、field1、field2、field3、field4、field5、field6、field7、field8、field9)

代碼實現

依賴引入

本文用的是junit測試類

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.18</version>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-core</artifactId>
            <version>5.5.6</version>
        </dependency>
    </dependencies>

設計實體類

實體類包含了所有的字段

package com.leo;
import lombok.Data;
import java.io.Serializable;
@Data
public class TestObj implements Serializable {
    private static final long serialVersionUID = 1L;
    String provinceId;
    String field1;
    String field2;
    String field3;
    String field4;
    String field5;
    String field6;
    String field7;
    String field8;
    String field9;
}

測試代碼

    /**
     * 測試類
     */
    @Test
    public void streamConcat2() {
        TestObj t0 = new TestObj();
        t0.setProvinceId("000");
        t0.setField1("1");
        t0.setField2("2");
        t0.setField3("3");
        TestObj t1 = new TestObj();
        t1.setProvinceId("100");
        t1.setField1("1");
        t1.setField2("2");
        t1.setField3("3");
        TestObj t2 = new TestObj();
        t2.setProvinceId("100");
        t2.setField4("4");
        t2.setField5("5");
        t2.setField6("6");
        TestObj t3 = new TestObj();
        t3.setProvinceId("100");
        t3.setField7("7");
        t3.setField8("8");
        t3.setField9("9");
        TestObj t4 = new TestObj();
        t4.setProvinceId("102");
        t4.setField7("7");
        t4.setField8("8");
        t4.setField9("9");
        List<TestObj> list1 = new ArrayList<>();
        list1.add(t0);
        list1.add(t1);
        List<TestObj> list2 = new ArrayList<>();
        list2.add(t2);
        List<TestObj> list3 = new ArrayList<>();
        list3.add(t3);
        list3.add(t4);
        // 根據省份id進行分組,將同一個省的不同字段合并成一條數據對象
        List<TestObj> list = Stream.concat(Stream.concat(list1.stream(), list2.stream()), list3.stream())
                .filter(e -> e != null)
                .collect(Collectors.toMap(TestObj::getProvinceId, a -> a, (o1, o2) -> {
                    try {
                        // Hutool 的屬性拷貝,最后一個參數是設置為null的字段不拷貝
                        BeanUtil.copyProperties(o1, o2, CopyOptions.create().setIgnoreNullValue(true).setIgnoreError(true));
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                    return o2;
                })).values().stream().collect(Collectors.toList());
        // 打印數據
        list.stream().forEach(System.out::println);
    }
}

測試結果:

TestObj(provinceId=000, field1=1, field2=2, field3=3, field4=null, field5=null, field6=null, field7=null, field8=null, field9=null)
TestObj(provinceId=100, field1=1, field2=2, field3=3, field4=4, field5=5, field6=6, field7=7, field8=8, field9=9)
TestObj(provinceId=102, field1=null, field2=null, field3=null, field4=null, field5=null, field6=null, field7=7, field8=8, field9=9)

以每個省id作為進行數據分組,一個省只有一行數據,將其他有值的字段合并到這一行數據上

到此這篇關于Java分析Lambda表達式Stream流合并分組內對象數據合并的文章就介紹到這了,更多相關Lambda Stream流合并內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java微信公眾平臺開發(fā)(5) 文本及圖文消息回復的實現

    Java微信公眾平臺開發(fā)(5) 文本及圖文消息回復的實現

    這篇文章主要為大家詳細介紹了Java微信公眾平臺開發(fā)第五步,回文本及圖文消息回復的實現代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • SpringBoot favicon Chrome設置問題解決方案

    SpringBoot favicon Chrome設置問題解決方案

    在本篇文章里小編給大家分享的是關于SpringBoot favicon Chrome設置問題實例內容,小的朋友們可以參考學習下。
    2020-02-02
  • Spring定時任務實現與配置(二)

    Spring定時任務實現與配置(二)

    這篇文章主要為大家詳細介紹了Spring定時任務的實現與配置第二篇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • java(jdk)環(huán)境變量配置(XP、win7、win8)圖文教程詳解

    java(jdk)環(huán)境變量配置(XP、win7、win8)圖文教程詳解

    對于初學java的同學來說,第一件事不是寫hello world,而是搭建好java開發(fā)環(huán)境,下載jdk,安裝,配置環(huán)境變量。這些操作在xp、win7、win8不同的操作系統(tǒng)里面配置不太一樣,下面通過本文給大家介紹如何在上面不同操作系統(tǒng)下配置
    2017-03-03
  • spring+netty服務器搭建的方法

    spring+netty服務器搭建的方法

    本篇文章主要介紹了spring+netty服務器搭建的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Java開發(fā)環(huán)境配置教程(win7 64bit)

    Java開發(fā)環(huán)境配置教程(win7 64bit)

    這篇文章主要為大家詳細介紹了win7 64bit下Java開發(fā)環(huán)境的配置教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Spring Native項目實戰(zhàn)(體驗79毫秒啟動springboot應用)

    Spring Native項目實戰(zhàn)(體驗79毫秒啟動springboot應用)

    Spring Native是Spring提供的、制作native image的技術方案,本篇主要內容是開發(fā)springboot應用再構建為native image的方法,通過Spring Native項目實戰(zhàn)讓大家體驗79毫秒啟動springboot應用,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • Kafka 安裝與配置詳細過程

    Kafka 安裝與配置詳細過程

    本節(jié)詳細介紹 Kafka 運行環(huán)境的搭建,為了節(jié)省篇幅,本節(jié)的內容以 Linux CentOS 作為安裝演示的操作系統(tǒng),其他 Linux 系列的操作系統(tǒng)也可以參考本節(jié)的內容,對Kafka 安裝與配置相關知識感興趣的朋友一起看看吧
    2021-11-11
  • SpringBoot 多環(huán)境配置和啟動詳解

    SpringBoot 多環(huán)境配置和啟動詳解

    這篇文章主要為大家介紹了SpringBoot多環(huán)境配置和啟動詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • servlet3文件上傳操作

    servlet3文件上傳操作

    這篇文章主要介紹了servlet3文件上傳操作的相關資料,需要的朋友可以參考下
    2017-11-11

最新評論