gpt4 book ai didi

java - 主线程中的SubscribeOn和observeOn

转载 作者:行者123 更新时间:2023-12-02 02:40:02 25 4
gpt4 key购买 nike

我尝试将 subscribeOn 和 obsereOn 与执行器一起使用,以便在异步任务完成后我可以返回主线程。我最终得到了这段代码,但它不起作用

@Test
public void testBackToMainThread() throws InterruptedException {
processValue(1);
processValue(2);
processValue(3);
processValue(4);
processValue(5);
// while (tasks.size() != 0) {
// tasks.take().run();
// }
System.out.println("done");
}

private LinkedBlockingQueue<Runnable> tasks = new LinkedBlockingQueue<>();


private void processValue(int value) throws InterruptedException {
Observable.just(value)
.subscribeOn(Schedulers.io())
.doOnNext(number -> processExecution())
.observeOn(Schedulers.from(command -> tasks.add(command)))
.subscribe(x -> System.out.println("Thread:" + Thread.currentThread().getName() + " value:" + x));
tasks.take().run();
}

private void processExecution() {
System.out.println("Execution in " + Thread.currentThread().getName());
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

知道如何实现我想要的吗?

当我运行时,我只打印

Execution in RxIoScheduler-2
Execution in RxIoScheduler-3
Execution in RxIoScheduler-4
Execution in RxIoScheduler-5
Execution in RxIoScheduler-6
done

问候

最佳答案

您的方法的问题在于,您无法知道在给定时间应该执行多少个任务,并且在等待解锁主线程后应该发生的任务时也不会出现死锁。

据我所知,任何 1.x 扩展都不支持返回 Java 主线程。对于 2.x,有 BlockingScheduler来自允许您执行此操作的扩展项目:

public static void main(String[] args) {
BlockingScheduler scheduler = new BlockingScheduler();

scheduler.execute(() -> {
Flowable.range(1,10)
.subscribeOn(Schedulers.io())
.observeOn(scheduler)
.doAfterTerminate(() -> scheduler.shutdown())
.subscribe(v -> System.out.println(v + " on " + Thread.currentThread()));
});

System.out.println("BlockingScheduler finished");
}

请注意对 scheduler.shutdown() 的调用,最终必须调用它来释放主线程,否则您的程序可能永远不会终止。

关于java - 主线程中的SubscribeOn和observeOn,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45648686/

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