基础

作者: 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的停止是一样的道理

相关文章

  • 机械设备安装技术

    设备基础种类及应用 垫层基础允许产生沉降:大型储罐 浅基础扩展基础联合基础:轧机独立基础 深基础桩基础:适用于需要...

  • 基础,基础,基础

    如果有人现在问我,JAVA该怎么学,我会告诉他不要急于求成,少看视频,多练,多思考。但说到这里有人可能会反...

  • 【Android】知识点汇总,坚持原创ing

    Android基础 Java基础 Java基础——Java内存模型和垃圾回收机制 语法基础 语法基础——C语法基础...

  • Java 基础

    Java 基础01Java开发入门 Java 基础02Java编程基础 Java 基础03面向对象 Java 基础...

  • 零基础学画画从入门到放弃

    零基础应该怎么学画画?零基础那就从基础开始学啊!基础是什么?造型基础和色彩基础。 造型基础就是用点线面组成起码能让...

  • 面试题汇总

    1.Java基础面试问题 Java基础之基础问题 Java基础之面向对象 Java基础之数据结构 Java基础之I...

  • 基础基础还是基础

    这次去面试,还是被基础给打趴下了。 对于PHP7的新特性没有了解。 对于TP的新特性没有了解。 再一个就是独立完成...

  • 零基础学UI设计需要美术基础吗?

    零基础学UI设计需要美术基础吗?零基础学UI设计需要美术基础吗?零基础学UI设计需要美术基础吗?零基础学UI设计需...

  • 基础基础!

    人生中第一个自主设计的实验方案终于得到认可^O^在设计方案过程中认识到基础知识以及细心的重要性,还有半个学期可以努...

  • Go语言基础语法--注释、基础结构2

    章节 GO语言基础语法--注释、基础结构(重要) 1.GO语言基础语法---注释、基础结构 基础结构注意事项 源文...

网友评论

      本文标题:基础

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