问题
I want to wrap a real listener to Observable object. For starters here is a test case, with him everything is fine.
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
getObservablePhoneState()
// Run on a background thread
.subscribeOn(Schedulers.io())
// Be notified on the main thread
.observeOn(AndroidSchedulers.mainThread())
.subscribe(integer -> Log.i(TAG, "----- subscribe onNext = " + integer));
}
private Flowable<Integer> getObservablePhoneState() {
return Flowable.create(emitter -> {
Log.i(TAG, "Emitting 1");
emitter.onNext(1);
Log.i(TAG, "Emitting 2");
emitter.onNext(2);
}, BackpressureStrategy.BUFFER);
}
*** logcat ***
Emitting 1
Emitting 2
----- subscribe onNext = 1
----- subscribe onNext = 2
This code generates an error:
private Flowable<Integer> getObservablePhoneState() {
return Flowable.create(emitter -> {
PhoneStateListener phoneStateListener = new PhoneStateListener() {
@Override
public void onCallStateChanged(int state, String incomingNumber) {
Log.i(TAG, "onCallStateChanged = " + state);
emitter.onNext(state);
}
};
TelephonyManager telephonyManager = (TelephonyManager) getActivity().getSystemService(Context.TELEPHONY_SERVICE);
telephonyManager.listen(phoneStateListener, PhoneStateListener.LISTEN_CALL_STATE);
}, BackpressureStrategy.BUFFER);
}
*** logcat ***
io.reactivex.exceptions.OnErrorNotImplementedException:
Attempt to read from field 'android.os.MessageQueue
android.os.Looper.mQueue' on a null object reference
With Observable.create() the same error. Perhaps this is due to the fact that RxJava2 does not support emitting a null value.
How to do it right?
回答1:
You should remove the subscribeOn(Schedulers.io())
to avoid creating the PhoneStateListener
in a different thread, because under the hood is trying to send messages using a Handler which mQueue is null. Just call
getObservablePhoneState()
.subscribe { integer -> Log.i("", "----- subscribe onNext = " + integer) }
来源:https://stackoverflow.com/questions/46332016/convert-wrap-async-listener-to-observable-rxjava2