Observable.create()subscribeOn和observeOn不工作

时间:2017-03-09 02:23:03

标签: java android multithreading rx-java2

在我的Android应用程序中,我使用了Rxjava2,但出现了一些奇怪的情况。

在我的Disposable我打印以记录当前线程名称:

    //1
    Observable
            .create((ObservableOnSubscribe<UserModel>) e -> {
                //mock io
                if (phoneNumber.equals("HolyHigh") && password.equals("111111")) {
                    e.onNext(new UserModel());
                    e.onComplete();
                } else {
                    e.onError(new RuntimeException("Error."));
                }
            })
            .subscribeOn(Schedulers.io())
            .observeOn(AndroidSchedulers.mainThread())
            .delay(1, TimeUnit.SECONDS)
            .subscribe(
                    r -> {
                        view.onLoginSuccess(new UserModel());
                        //test
                        String name = Thread.currentThread().getName();
                        Log.e("Thread Name", " Success Current Thread Name: " + name);
                    }
                    , e -> {
                        e.printStackTrace();
                        view.onLoginFailed(e.getMessage());
                        //test
                        String name = Thread.currentThread().getName();
                        Log.e("Thread Name", " Error Current Thread Name: " + name);
                    }
            );

然后记录:

Thread Name: Error Current Thread Name: RxComputationThreadPool-3

看起来像observeOn和subscribeOn不工作...... 为什么不是主线?

然而,我写了一些简单的......

//2
    Single.timer(1, TimeUnit.SECONDS)
            .subscribeOn(Schedulers.io())
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(r -> {
                Log.e("Single Thread Name", "Single Thread Name: " + Thread.currentThread().getName());
                CommonUtil.showToast(r + "~");
            });

并记录下来:

Single Thread Name: Single Thread Name: main

我的错误在哪里?...

1 个答案:

答案 0 :(得分:1)

delay()运算符默认在计算调度程序上运行,因此更改上游事件以在计算线程上获取通知。

您只需在订阅前更改它,只需在observeOn .observeOn(AndroidSchedulers.mainThread())运算符后移动delay()

顺便说一句,delay()还有一个带有Scheduler参数的重载,可让你更改默认的Scheduler