RxJava:OnNext Unsubscribe不起作用

时间:2016-12-28 18:07:26

标签: java java-ee rx-java reactive rx-java2

我在收到观察中的第一个项目后试图取消订阅。它似乎不起作用。我做错了什么?

    public class ObservableAndSubscriber {

    public static void main(final String[] args) {
        final Observable<String> strObservable = Observable.create(s -> {
            while (true) {
                s.onNext("Hello World!!");
            }
        });

        final Subscriber<String> strSubscriber = new Subscriber<String>() {

            @Override
            public void onCompleted() {

            }

            @Override
            public void onError(final Throwable e) {
                e.printStackTrace();

            }

            @Override
            public void onNext(final String t) {
                System.out.println(t);
                this.unsubscribe();

            }
        };
        strObservable.subscribe(strSubscriber);
    }
}

结果似乎在无限循环中打印“Hello World”。

2 个答案:

答案 0 :(得分:1)

要取消订阅工作,您需要检查循环中的订阅状态。否则它会无限地耗尽你的CPU。

处理无限顺序的最简单方法是利用库提供的方法Observable.generate()Observable.fromIterable()。他们会为你做适当的检查。

还要确保在不同的线程上订阅和观察。否则,您将只为单个用户提供服务。

你的例子:

strObservable = Observable.generate(g -> g.onNext("Hello!"));
strObservable.subscribeOn(Schedulers.newThread()).subscribe(strSubscriber);

答案 1 :(得分:0)

我在读Tomasz Nurkiewicz的书时做了这个例子。他后来有一个类似的例子,并解释了我的代码出了什么问题。

无限循环是邪恶的!因为,我在我的可观察创建lambda表达式中有一个,它在我的主线程的上下文中执行并无限期地订阅块。为了在不同的线程中获取可观察的创建lambda执行,这意味着主线程永远不会被阻塞并且subscribe()完成。我要求订阅发生在一个IO线程上,这就是诀窍,这意味着无限循环发生在IO线程上并且不会阻塞主线程。

strObservable.subscribeOn(Schedulers.io()).subscribe(strSubscriber);