Stream API 利用Filter函数对没有实现Comperable接口对象做自定义去重并使用嵌套函数合并数量处理及利用Collectors收集器Collector.toMap()进行分批递增处理

class MyObj {
    String name;
    BigDecimal num;
    public void setName(String name) {
        this.name = name;
    }
    public String getName() {
        return name;
    }
    public void setNum(BigDecimal num) {
        this.num = num;
    }
    public String getNum() {
        return num;
    }
    public MyObj(String name, BigDecimal num) {
        this.name = name;
        this.num = num;
    }
}

        

// 批次单位
int batchNum = 2;
// 使用流处理
List<MyObj> list = new ArrayList<MyObj> () {
  {
    add(new MyObj("a", 1));
    add(new MyObj("a", 2));
    add(new MyObj("b", 3));
    add(new MyObj("b", 4));
}};

list.stream()
    // 去重合并数量
    .filter(compareAndOperator(MyObj::getName, MyObj::getNum, t -> (a, b) -> t.setNum(a.add(b))))
    // 若 inputDat > 1000  则将 inputData 切割为以1000个为单位分组映射 key自增
    .collect(Collectors.groupingByConcurrent(incrSplitOf(batchNum), Collec
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值