Android 在IO线程上调用doOnSubscribe

Android 在IO线程上调用doOnSubscribe,android,multithreading,kotlin,rx-java2,Android,Multithreading,Kotlin,Rx Java2,我有以下代码: checkZipCode.exec(it) .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .doOnSubscribe { Timber.d("Main thread: ${Looper.getMainLooper().isCurrentThread}") view.showLoading(true) } .d

我有以下代码:

checkZipCode.exec(it)
    .subscribeOn(Schedulers.io())
    .observeOn(AndroidSchedulers.mainThread())
    .doOnSubscribe {
        Timber.d("Main thread: ${Looper.getMainLooper().isCurrentThread}")
        view.showLoading(true)
    }
    .doOnDispose { view.showLoading(false) }
    .flatMapMaybe { isZipValid ->
        if (isZipValid) {
            userModel.zipCode = it.toString()
            saveUser.exec(userModel)
            autoSelectCityIfSingle.exec()
        } else {
            // TODO: Should show error here?
            Maybe.empty()
        }
    }
    .subscribe(...)
日志为:
主线程:false


我认为
doOnSubscribe
是在它上面的最新调度程序上调用的。不是吗?

订阅执行路径并不是一个真正的发射,它由
observeOn
执行。看见
. 如果你真的想让某件事情发生在你的链中该点的主线程上,也许你可以在另一个
可观察的
中进行平面映射,这将在它的
doOnSubscribe
中做一些事情(因为这将发生在发射线程上,这是这里的主线程)。

好吧,
doOnSubscribe
subscribe()
在同一线程上执行

我遇到问题,因为在I/O线程上调用了subscribe()