如何在 Android 上使用 RxJava 运行 订阅多个线程

How to run subsciber on multiple threads with RxJava on Android

我是 RxJava 的新手,正在努力解决一个(我猜)简单的问题。我想在 3 个线程中同时处理订阅部分。这就是我使用 FixedThreadPool 的原因。示例代码:

Observer.just("one", "two", "three", "four")
.observeOn(Schedulers.io())
.subscribeOn(Schedulers.from(Executors.newFixedThreadPool(3))
.subscribe(new Observer<String>() {

    public void onNext(String string) {
        Log.d(TAG, "Started: " + string);
        SystemClock.sleep(1000);
        Log.d(TAG, "Ended: " + string);
    }

    (...)

}

预期结果:

Started: one
Started: two
Started: three
Ended: one
Started: four
Ended: two
Ended: three
Ended: four

实际结果:

Started: one
Ended: one
Started: two
Ended: two
Started: three
Ended: three
Started: four
Ended: four

我做错了什么?

RxJava Observables 是顺序的,subscribeOnobserveOn 运算符不会 运行 值彼此并行。

最接近的做法是通过模键对值进行分组,运行 通过 observeOn 对值进行分组,然后合并结果:

AtomicInteger count = new AtomicInteger();

Observable.range(1, 100)
.groupBy(v -> count.getAndIncrement() % 3)
.flatMap(g -> g
    .observeOn(Schedulers.computation())
    .map(v ->  Thread.currentThread() + ": " + v))
.toBlocking()
.forEach(System.out::println);