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
Stream API 利用Filter函数对没有实现Comperable接口对象做自定义去重并使用嵌套函数合并数量处理及利用Collectors收集器Collector.toMap()进行分批递增处理
最新推荐文章于 2023-10-28 17:35:43 发布