1

从可观察对象接收到第一个项目后,我试图取消订阅。它似乎不起作用。我究竟做错了什么?

    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”。

4

2 回答 2

1

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

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

还要确保您订阅并观察不同的线程。否则,您将只为单个订阅者提供服务。

你的例子:

strObservable = Observable.generate(g -> g.onNext("Hello!"));
strObservable.subscribeOn(Schedulers.newThread()).subscribe(strSubscriber);
于 2017-01-11T13:33:19.493 回答
0

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

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

strObservable.subscribeOn(Schedulers.io()).subscribe(strSubscriber);
于 2016-12-28T18:45:21.537 回答