RxJava简单理解

2019-05-20  本文已影响0人  追风之猪

要用RxJava,那么就得先了解两个概念

Observable察者

Observer观察

比如放羊,羊是被观察者,放羊娃就是观察者,当羊饿了的时候,咩咩的叫个不停,相当于向放羊娃发出信号说我饿了,你看着办,放羊娃呢,在听到羊的叫声后就会做出相应的处理.那么这里前提是二者要关联成为观察与被观察的关系.否则没有关联的关系,放羊娃才不会那么傻去喂养和自己没关系的羊.

观实者与被观察者就是这样的状态,本来各不相干,但是一旦二者关联,那么观察者就和被观察者形成关系,观察者会对被观察者的言行举止做出相应的响应.

Observable察者(小羊)

首先是被观察者的创建:(羊来了)

Observable observable = Observable.create(new ObservableOnSubscribe() {

@Override

public void subscribe(ObservableEmitter e) throws Exception {

                  //  羊咩咩的叫个不停于是用e向外发射信号

                    e.onNext("我饿了");

}

});

此处有两个概念:

ObservableOnSubscribe : 一个接口,创建被观察者时需要传入他的实例

ObservableEmitter : 事件发射器

create方法做了判空处理后,返回了ObservableCreate的实例

ObservableCreate是Observable的子类实现

Observer 观察者(放羊娃)

观察者的创建

Observer observer = new Observer() {

@Override

public void onSubscribe(Disposable d) { }

@Override

public void onNext(String s) {

// 接收到羊发来的信号s,我知道啦,马上给你准备草去

}

@Override

public void onError(Throwable e) {}

@Override

public void onComplete() {    }

};

Observer用来对被观察者发射出的事件做相应的处理,也可理解为对监听到被观察者的相应的状态做出相应的处理.

observable.subscribe(observer);

最后通过subscribe方法完成被观察者与观察者的订阅连接 ,此时羊与放羊娃明确关系.

subscribe方法内部实现其实最终调用的是observable的subscribeActual 实现方法

@Override

protected void subscribeActual(Observer observer) {

CreateEmitter parent = new CreateEmitter(observer);

observer.onSubscribe(parent);

try {

source.subscribe(parent);

} catch (Throwable ex) {

Exceptions.throwIfFatal(ex);

parent.onError(ex);

}

}

可以看到,该方法会将我们传入的observer再次传给CreateEmitter, CreateEmitter是ObservableCreater 的一个内部类,同时实现了ObservableEmitter,Disposable这两个接口,相当于关联了Observer的基础上又做了进一步的封装,因为其内部实现最终事件的执行都是通过传入的observer来完成的

其持有了observer实例后,在可以执行observer的相应事件方法的基础上进一步的添加了一些控制订阅,以及状态判断的方法.如下源码可见:

static final class CreateEmitter

extends AtomicReference

implements ObservableEmitter, Disposable {

private static final long serialVersionUID = -3434801548987643227L;

final Observer observer;

CreateEmitter(Observer observer) {

this.observer = observer;

}

@Override

public void onNext(T t) {

if (t == null) {

onError(new NullPointerException("onNext called with null. Null values are generally not allowed in 2.x operators and sources."));

return;

}

if (!isDisposed()) {

observer.onNext(t);

}

}

@Override

public void onError(Throwable t) {

if (!tryOnError(t)) {

RxJavaPlugins.onError(t);

}

}

@Override

public boolean tryOnError(Throwable t) {

if (t == null) {

t = new NullPointerException("onError called with null. Null values are generally not allowed in 2.x operators and sources.");

}

if (!isDisposed()) {

try {

observer.onError(t);

} finally {

dispose();

}

return true;

}

return false;

}

@Override

public void onComplete() {

if (!isDisposed()) {

try {

observer.onComplete();

} finally {

dispose();

}

}

}

@Override

public void setDisposable(Disposable d) {

DisposableHelper.set(this, d);

}

@Override

public void setCancellable(Cancellable c) {

setDisposable(new CancellableDisposable(c));

}

@Override

public ObservableEmitter serialize() {

return new SerializedEmitter(this);

}

@Override

public void dispose() {

DisposableHelper.dispose(this);

}

@Override

public boolean isDisposed() {

return DisposableHelper.isDisposed(get());

}

}

ObservableEmitter也是一个接口,是Emitter的子类,如下源码:

public interface ObservableEmitter extends Emitter

public interface Emitter {

/**

* Signal a normal value.

* @param value the value to signal, not null

*/

void onNext(@NonNull T value);

/**

* Signal a Throwable exception.

* @param error the Throwable to signal, not null

*/

void onError(@NonNull Throwable error);

/**

* Signal a completion.

*/

void onComplete();

}

***********************************************************

public interface Disposable {

/**

* Dispose the resource, the operation should be idempotent.

*/

void dispose();

/**

* Returns true if this resource has been disposed.

* @return true if this resource has been disposed

*/

boolean isDisposed();

}

onSubscribe方法将观察者和emmitter发射器关联起来,

往下走source.subscribe(parent);

此处的source就是我们在创建被观察者是传入的(new ObservableOnSubscribe())

至此可以看到ObservableOnSubscribe实例的subscriber方法将自身与关联了Observer的事件发射器进行了关联.

总结

1.被观察者Observabler的创建最终返回的是ObservableCreate的实例,所以被观察者Observabler的状态以及事件的执行都是通过ObservableCreate的内部类CreateEmitter来实现的,

2.CreateEmitter对订阅的Observer进行了关联封装

3.被观察者Observable通过subscribe方法将观察者传给他的内部类CreateEmitter用来进行关联封装.

4.ObservableCreate创建的时候接收了Observable.create方法传入的(newObservableOnSubscribe())并与自身的内部类CreateEmitter进行了关联

5.被观察者Observabler要执行的事件都会在传入的ObservableOnSubscribe实例的subscriber方法中进行操作再经由关联的CreateEmitter向外发射.最终由CreateEmitter关联封装的Observer接收事件并作出响应.

上一篇下一篇

猜你喜欢

热点阅读