猿问

如何对 Flux 进行移动窗口计算并将结果输出为新的 Flux

我想对 Flux 执行移动窗口计算并生成包含计算值的 Flux,但我不知道如何完成此操作。

作为一个简化的例子,假设我有一个整数通量,我想用这个通量中每 3 个连续整数的总和生成一个新的通量。为了显示:

第一个通量包含从 1 到 8 的整数:{1, 2, 3, 4, 5, 6, 7, 8}

结果通量应包含总和:{1+2+3、2+3+4、3+4+5、4+5+6、5+6+7、6+7+8}

我可以轻松地生成第一个 Flux 并导出包含连续 3 个值的通量通量,如下所示:

Flux<Integer> f1 = Flux.range(1,8);
Flux<Flux<Integer>> f2 = f1.window(3,1);

我也可以订阅 () 到 f2 并计算总和,但我不知道如何同时将这些总和发布为新的 Flux。

我错过了一些简单的事情,还是这种事情真的很难做?


神不在的星期二
浏览 68回答 1
1回答

HUWWW

您可以使用.reduce(Integer::sum)内部通量来执行窗口中元素的总和,并.flatMap使用外部通量将这些总和合并回单个流。请注意,由于.window调用 with maxSize < skip,因此尾随窗口中的项目将小于最大大小。Flux<Integer> sums = Flux.range(1, 8)&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; // Flux<Integer>&nbsp; &nbsp; &nbsp; &nbsp; .window(3, 1)&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; // Flux<Flux<Integer>>&nbsp; &nbsp; &nbsp; &nbsp; .flatMap(window -> window.reduce(Integer::sum)); // Flux<Integer>StepVerifier.create(sums)&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(6)&nbsp; // 1+2+3&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(9)&nbsp; // 2+3+4&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(12) // 3+4+5&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(15) // 4+5+6&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(18) // 5+6+7&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(21) // 6+7+8&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(15) // 7+8&nbsp; &nbsp; &nbsp; &nbsp; .expectNext(8)&nbsp; // 8&nbsp; &nbsp; &nbsp; &nbsp; .verifyComplete();
随时随地看视频慕课网APP

相关分类

Java
我要回答