我有一个具有不同对象类型的通量,我希望按类型分组元素,然后减少每个组。
这是一个简单的代码来执行此操作。
Flux<Item> item=Flux.just(new Item("item1"), new Item("item2"));
Flux<Item2> item2=Flux.just(new Item2(4.0f), new Item2(2.0f));
Flux<Object> objects=Mono.empty().concatWith(item).concatWith(item2);
Flux<GroupedFlux<Object>> groups=objects.groupBy(value -> value.getClass());
如何按类型减少每个流量?enter code here
答案 0 :(得分:2)
我在gitter上找到了解决方案。感谢@simonbasle和@osi for reactiviy。
https://gitter.im/reactor/reactor
关键是方法flatMap并使用键来区分值。
groups.flatMap(gf -> {
if(gf.key()==Item.class) {
return gf.reduce(new Item(""), (a, b) -> {
return new Item(a.getValue()+((Item)b).getValue());
});
}
else if(gf.key()==Item2.class) {
return gf.reduce(new Item2(0.0f), (a, b) -> {
return new Item2(a.getValueF()+((Item2)b).getValueF());
});
}
throw new IllegalArgumentException("unknown key: "+gf.key());
});