本文适合使用过Rxjava2或者了解Rxjava2的基本用法的同学阅读

一.Rxjava是什么

Rxjava在GitHub 主页上的自我介绍是 “a library for composing asynchronous and event-based programs using observable sequences for the Java VM”(一个在 Java VM 上使用可观测的序列来组成异步的、基于事件的程序的库)。

通俗来说,Rxjava是一个采用了观察者模式设计处理异步的框架。链式调用设计让代码优雅易读。

举个例子:

    Observable<String> observable = Observable.create(new ObservableOnSubscribe<String>() {

        @Override
        public void subscribe(ObservableEmitter<String> e) throws Exception {
            e.onNext("a");
        }
    });

    observable.subscribe(new Observer<String>() {
        @Override
        public void onSubscribe(Disposable d) {

        }

        @Override
        public void onNext(String s) {

        }

        @Override
        public void onError(Throwable e) {

        }

        @Override
        public void onComplete() {

        }
    });

这是Rxjava2最简单的用法:

1.创建一个Observable,重写subscribe方法,这里主要处理被观察的事件。

2.订阅这个Observable,事件会回调observer的方法,我们可以对事件做响应的处理

二.Rxjava源码解析

2.1. 创建Observable:

创建Observable用的是Observable.create(ObservableOnSubscribe source)方法。这个方法的参数是ObservableOnSubscribe:

public interface ObservableOnSubscribe<T> {

    /**
     * Called for each Observer that subscribes.
     * @param e the safe emitter instance, never null
     * @throws Exception on error
     */
    void subscribe(@NonNull ObservableEmitter<T> e) throws Exception;
}

ObservableOnSubscribe是一个接口,唯一的方法是subscribe,参数是ObservableEmitter e。ObservableEmitter是一个继承了Emitter的接口,接口Emitter里定义了onNext、onError、onComplete等方法,和Observer(观察者)的方法相对应。

public interface Emitter<T> {

    /**
     * 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();
}

ObservableEmitter对接口Emitter进行扩展,增加了setDisposable、setCancellable等方法

基本参数了解了,现在看看create方法里面做了什么,代码如下:

public static <T> Observable<T> create(ObservableOnSubscribe<T> source) {
        return RxJavaPlugins.onAssembly(new ObservableCreate<T>(source));
    }

调用了RxJavaPlugins的onAssembly方法。又有一个新参数ObservableCreate(source),我们看看它是什么:

final class ObservableCreate<T> extends Observable<T> {

    public ObservableCreate(ObservableOnSubscribe<T> source) {
        this.source = source;
    }

}

继承了Observable,所以也是个被观察对象,在构造函数中我们看到我们new的ObservableOnSubscribe对象,被存在了ObservableCreate的source里面

那我们继续看看onAssembly方法做什么:

public static <T> Observable<T> onAssembly(@NonNull Observable<T> source) {
        Function<? super Observable, ? extends Observable> f = onObservableAssembly;
        if (f != null) {
            return apply(f, source);
        }
        return source;
    }

一个Hook方法。onObservableAssembly是一个静态变量,我们没有设置,默认为空,所以直接返回source对象。也就是说,Observable的create方法其实就是把我们ObservableOnSubscribe对象,存储在ObservableCreate对象的source里面,然后返回ObservableCreate对象。

我们知道ObservableCreate是继承Observable的,所以创建了ObservableCreate对象,我们的Observable也就创建完了。

2.2 订阅事件(被观察者)

订阅被观察者的操作是observable.subscribe(new Observer())。这个操作符其实是个“被动”,就是事件被观察者观察。因为subscribe方法里的参数Observer才是观察者。我们也会在Observer里的各个会调方法里接收到事件相关的返回值。

我们看看subscribe方法的源码:

public final void subscribe(Observer<? super T> observer) {
    try {
        subscribeActual(observer);
    } catch (NullPointerException e) { // NOPMD
        throw e;
    } catch (Throwable e) {
        RxJavaPlugins.onError(e);
    }
}

看代码我们知道最主要调用的方法是:subscribeActual(observer);,这个方法是Observable里的抽象方法,而此时我们的Observable是一个ObservableCreate对象(前面create方法返回的对象)。所以我们去看一下ObservableCreate里面是如何重写这个方法的。代码如下:

 public final void subscribe(Observer<? super T> observer) {
        try {
            subscribeActual(observer);
        } catch (NullPointerException e) { // NOPMD
            throw e;
        } catch (Throwable e) {
            RxJavaPlugins.onError(e);
        }
    }

我们一看到这个方法主要做了三件事:

①创建一个CreateEmitter对象parent。

②把parent传给source的subscribe方法。上面我们知道source就是刚才存的ObservableOnSubscribe对象,subscribe也就是我们重写的方法:

 @Override
            public void subscribe(ObservableEmitter<String> e) throws Exception {
                e.onNext("a");
            }

所以我们在这个方法里就能收到一个CreateEmmiter,通过CreateEmitter可以回调相应的方法。CreateEmitter是实现ObservableEmitter接口,我们看看它内部实现,如:onNext源码如下:

@Override
public void onNext(T t) {
    observer.onNext(t);
}

也就是说,当我们在ObservableOnSubscribe的subscribe方法里调用ObservableEmitter的onNext方法的时候,它里面会调用observer的onNext。于是通过这样的传递,我们就能在observer里响应的回调方法里收到事件的相关状态。

至此一个简单Rxjava流式传递原理已经讲完了,总结流程如下:

  • 使用Observbable.create方法,产生一个ObservableCreate对象,对象里存着ObservableOnSubscribe对象source。
  • 调用ObservableCreate.subscribe方法,实际调用的是subscribeActual方法,传入一个Observer对象。
  • subscribeActual方法中创建一个CreateEmmiter对象,调用source.subscribe方法,传入CreateEmmiter对象。
  • 于是我们在ObservableOnSubscribe中就接收到了一个CreateEmmiter,CreateEmmiter是ObservableEmmiter的子类。我们可以在这里调用CreateEmmiter的方法进行事件回调。
  • 调用CreateEmmiter方法,实际上会调用Observer的响应的方法。也就是CreateEmmiter把事件状态传递给观察者。

最新文章

  1. ITIS-资料集合贴
  2. hdu3247Resource Archiver(ac自动机+spfa)
  3. C#—打开文件
  4. Thinkpad X240使用U盘安装Win7系统
  5. seajs集成jquery的一个坑
  6. HTML—one
  7. Java基础—ClassLoader的理解
  8. ANDROID_MARS学习笔记_S02_010_Animation_动画效果
  9. WSImport
  10. 杭电21题 Palindrome
  11. HTML核心标签之表格标签(一)
  12. LoadRunner 11 error:Cannot initialize driver dll
  13. 虚函数 error LNK2001: 无法解析的外部符号 &quot;public: virtual void __cdecl
  14. FPGA笔试必会知识点1--数字电路基本知识
  15. NOIP初赛知识点大全-普及+提高组
  16. 【2019北京集训3】逻辑 树剖+2-sat
  17. L1比L2更稀疏
  18. Spark机器学习(4):朴素贝叶斯算法
  19. iOS cell左滑出现多个功能按钮(IOS8以后支持)
  20. 解决 swap file “*.swp”already exists!问题

热门文章

  1. 2018-2019-2 20165232《网络对抗技术》Exp1 缓冲区溢出实验
  2. HBase 在HDFS上的物理目录结构
  3. [源码分析]读写锁ReentrantReadWriteLock
  4. 第十二节:WebApi自动生成在线Api文档的两种方式
  5. 发送邮件,出现异常:服务器响应为: Error: need EHLO and AUTH first !&quot;
  6. Bootstrap常用样板
  7. mysql并发控制之MVCC
  8. centos7 nginx配置ssl证书实现https访问同时http访问
  9. React 轮播图实现
  10. C# 用Serializer.ToXml()方法转换成两种格式的XML