gpt4 book ai didi

kotlin - Reactor-加载分页API的所有页面

转载 作者:行者123 更新时间:2023-12-02 13:34:44 28 4
gpt4 key购买 nike

我想知道Reactor和分页的HTTP API。我有一个private fun getPage(pageNumber: Int): Mono<SomePaginatedResouce>。该资源具有“numberOfPages”字段,我想获取所有页面。

第一次尝试如下:

getPage(1)
.map { it.numberOfPages }
.flatMapMany { Flux.range(1, it) }
.flatMap { getPage(it) }

它可以正常工作并获取我的数据。但是,我想避免两次请求首页。所以我在想:
getPage(1)
.expand { it ->
if (it.isFirst) {
// If it is the first page, load the rest of the pages
Flux.range(2, it.numberOfPages)
.flatMap { getPage(it) }
} else {
// If it is a subsequent page, don't load anything
Flux.empty()
}
}

有没有比使用 expand并在我的资源中引入特殊标志更好的方法呢?

最佳答案

您可以执行以下操作:

getPage(1).flatMapMany(
it -> Flux.concat(Mono.just(it), Flux.range(2, it.numberOfPages - 1).flatMap(this::getPage))
);

害怕它是Java而不是Kotlin,但翻译起来应该微不足道。

(请记住, Flux.range()适用于“开始”和“计数”参数,而不适用于“第一个索引”和“最后一个索引”。)

关于kotlin - Reactor-加载分页API的所有页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59355745/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com