基础

作者: sponiza | 来源:发表于2017-05-13 14:51 被阅读0次

    注:本文分析的是RxJava 2.0.0 阅读之前,希望你对RxJava1已经有所了解。
    首先了解几个基本接口

    public interface Emitter<T> 
        void onNext(T value);
        void onError(Throwable error);
        void onComplete();
    
    public interface ObservableEmitter<T> extends Emitter<T>
        void setDisposable(Disposable d);
        void setCancellable(Cancellable c);
        boolean isDisposed();
        ObservableEmitter<T> serialize();
    
    public interface Disposable {
        void dispose();
        boolean isDisposed();
    

    和第一版的Subscriber挺像的,把Subscriber拆分出了几部分
    再看一个接口

    public interface Observer<T>
        void onSubscribe(Disposable d);
        void onNext(T value);
        void onError(Throwable e);
        void onComplete();
    

    其中onSubscribe和第一版Subscriber的onStart方法类似
    第二版多了个Disposable参数,让你可以取消。
    我们可以写这个接口的子类,订阅的时候使用

    作为开始,先写一个超级简单的例子:

    Observable
           .create(new ObservableOnSubscribe<String>() {
          @Override public void subscribe(ObservableEmitter<String> e) throws Exception {
            e.onNext("1"); } })
            .subscribe(new Observer<String>() {
              @Override public void onSubscribe(Disposable d) {}
              @Override public void onNext(String value) { }
              @Override public void onError(Throwable e) {}
              @Override public void onComplete() {}
            });
    

    (排版有点糟糕,先将就一下~~)
    create方法接受一个ObservableOnSubscribe对象
    ObservableOnSubscribe是一个接口,只有一个方法

    public interface ObservableOnSubscribe<T> 
        void subscribe(ObservableEmitter<T> e) throws Exception;
    

    ObservableEmitter这个接口在开始的时候提到过
    看看create的源码:

    public static <T> Observable<T> create(ObservableOnSubscribe<T> source) {
            ObjectHelper.requireNonNull(source, "source is null");
            return RxJavaPlugins.onAssembly(new ObservableCreate<T>(source));
        }
    

    先判空
    RxJavaPlugins.onAssembly是一个hook,类似于监听,不设置的话传入什么就返回什么
    所以这里返回的是ObservableCreate对象
    ObservableCreate继承了Observable,Observable是一个基类,也是一个抽象类
    Observable规定了被观察者的基本流程,具体实现由子类完成
    ObservableCreate的构造,仅仅是接口保存起来

    现在来看subscribe方法
    里面经过一些检查后,会调用subscribeActual方法
    这个方法是abstract的
    前面我们得到的实际上是ObservableCreate对象,所以这个具体实现在ObservableCreate里面

    protected void subscribeActual(Observer<? super T> observer) {
            CreateEmitter<T> parent = new CreateEmitter<T>(observer);
            observer.onSubscribe(parent);
    
            try {
                source.subscribe(parent);
            } catch (Throwable ex) {
                Exceptions.throwIfFatal(ex);
                parent.onError(ex);
            }
        }
    

    可以看到,这里用CreateEmitter包装了observer,这个observer就是订阅时传入的observer
    然后,调用onSubscribe方法
    之后,source就是create的时候传入的接口,终于回到我们的自定义方法了
    然而,这个时候,我们和observer还隔着一个CreateEmitter
    先看看CreateEmitter部分代码:

     @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 (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();
                    }
                } else {
                    RxJavaPlugins.onError(t);
                }
            }
    
            @Override
            public void onComplete() {
                if (!isDisposed()) {
                    try {
                        observer.onComplete();
                    } finally {
                        dispose();
                    }
                }
            }
    

    onNext: 检查发射的值是否为null, observer是否已取消观察, 然后才交给observer
    注意,异常需要自己处理
    onComplete:检查observer是否已取消观察, 交给observer, 最后调用dispose
    onError: 检查异常是否为null, observer是否已取消观察, 然后才交给observer, 最后dispose
    注意,要保证onComplete和onError只能调用一次

    再来看看取消观察
    CreateEmitter继承了AtomicReference
    也就是说这个类有一个变量,这个变量用来标志是否已经取消。
    调用dispose最终会调用这个方法

    public static boolean dispose(AtomicReference<Disposable> field) {
            Disposable current = field.get();
            Disposable d = DISPOSED;
            if (current != d) {
                current = field.getAndSet(d);
                if (current != d) {
                    if (current != null) {
                        current.dispose();
                    }
                    return true;
                }
            }
            return false;
        }
    

    简单来说,就是把这个标志设置为DISPOSED,DISPOSED就是一个单例。

    isDispose方法:

    public static boolean isDisposed(Disposable d) {
            return d == DISPOSED;
        }
    

    很简单,看这个标志是否等于DISPOSE

    回顾一下,在create的时候返回ObservableCreate对象,这个对象保存了传入的接口
    subscribe的时候,传入的observer会到达ObservableCreate,进行包装,然后交给create时我们的自定义处理
    取消订阅就是设置标志位,本身并不会做些什么,这和Thread的停止是一样的道理

    相关文章

      网友评论

          本文标题:基础

          本文链接:https://www.haomeiwen.com/subject/jiuxxxtx.html