gpt4 book ai didi

java - 使用 RxJava fork 任务并合并结果

转载 作者:行者123 更新时间:2023-11-30 07:50:00 29 4
gpt4 key购买 nike

我正在尝试执行以下操作:

                           A
|
|
V
Observable<B>
/\
/ \
/ \
V V
Observable<C> Observable<D>
\ /
\ /
V V
Observable<E>
  1. 给定输入 [A],异步调用返回 [B]。
  2. 两个各自需要[B]的任务需要并行运行,分别返回[C]和[D]。
  3. 这两个结果合并为 [E],然后显示在 UI 中。

我是RxJava的新手,遇到过zip、merge等,但是不太明白这类问题需要什么操作符。任何帮助将不胜感激。

附言。1) 虽然 [C] 和 [D] 都是必需的,但 [E] 仍然可以只用其中之一创建。因此,如果其中一个(或两个)失败,最好在此时设置超时。
2) 是否可以让它们在特定线程中运行 - 一个在 computation() 中,另一个在 io() 中?

这是我目前拥有的概念代码。我这样做是线性的:
A -> B -> C -> D -> E

    return a2b(a)
.subscribeOn(Schedulers.io())
.flatMap(this::b2c)
.subscribeOn(Schedulers.computation())
.map(this::c2d)
.map(this::d2e)
.cast(E.class)
.startWith(e -> new E.loadingState());

理想情况下,我应该在某处使用以下函数:

Observable<E> cd2e(C c, D d) {
return Observable.just(new E());
}

谢谢。

最佳答案

publish() 运算符以允许多个订阅的方式绑定(bind)单个可观察对象。

return a2b(a)
.subscribeOn(Schedulers.io())
.publish( bObservable ->
Observable.zip( bObservable.map( b -> this::b2c ),
bObservable.map( b -> this::b2d ),
(c, d) -> combine( c, d ) )
.subscribe( ... );

运营商绑定(bind)观察者链,以便可以进行多个订阅;在这种情况下,订阅被压缩在一起,将 CD 类型组合成组合的 E 类型。

然后您可以自由添加 observeOn() 运算符以在您想要的线程上完成计算。

关于java - 使用 RxJava fork 任务并合并结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48015796/

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