重学Android——Rxjava2.x源码解析

Rxjava的诞生背景

首先要从异步编程说起,最开始的原生的系统中,如果UI系统处理耗时任务,会引发ANR,所以都是放在子线程做耗时任务,比如网络请求或者IO操作,再来更新UI界面,这需要在主线程来完成,这样就涉及到了异步编程。

最开始的异步编程主要有:

  • 使用Java自身提供的Future模型
    • 但这种异步结果获取比较困难,必须调用Future.get(),回去查看异步是否完成,如果完成,就返回结果,否则继续等待。当然在JDK8后,提供了completabelFuture,简化了异步编程
  • Android系统提供的异步模型——AsyncTask。相比于Java提供的方法,此模型无主线程阻塞风险,但是最大的问题是有可能陷入层层嵌套的回调。

Rxjava源码中链式调用

多说也无益,先看源码。

分析问题时,我们可以从特殊到普通来分析,有时候会有意想不到的效果,所以这次源码由Single开始分析,我们最简单的用法:

先在app的gradle中

    implementation "io.reactivex.rxjava2:rxjava:2.2.9"
    implementation 'io.reactivex.rxjava2:rxandroid:2.1.1'
最简单的实现
        Single.just(1)
                .subscribe(new SingleObserver<Integer>() {
   
            @Override
            public void onSubscribe(Disposable d) {
   

            }

            @Override
            public void onSuccess(Integer integer) {
   

            }

            @Override
            public void onError(Throwable e) {
   

            }
        });
    }

这是最简单的用法,上游发送一个1的事件,下游接到,不牵涉线程切换。

创建被观察者

我们先直接进Just的源码

    @CheckReturnValue
    @SchedulerSupport(SchedulerSupport.NONE)
    @NonNull
    public static <T> Single<T> just(final T item) {
   
        //判空
        ObjectHelper.requireNonNull(item, "item is null");
        //HOOK方法
        return RxJavaPlugins.onAssembly(new SingleJust<T>(item));
    }

第一行,其实看方法名我们也能看出来,是判空的,源码如下

    public static <T> T requireNonNull(T object, String message) {
   
        if (object == null) {
   
            throw new NullPointerException(message);
        }
        return object;
    }

果然不出所料,忽略

第二行,先看外层的RxJavaPlugins.onAssembly,进它的源码

    /**
     * Calls the associated hook function.
     * @param <T> the value type
     * @param source the hook's input value
     * @return the value returned by the hook
     */
    @SuppressWarnings({
    "rawtypes", "unchecked" })
    @NonNull
    public static <T> Single<T> onAssembly(@NonNull Single<T> source) {
   
        Function<? super Single, ? extends Single> f = onSingleAssembly;
        if (f != null) {
   
            return apply(f, source);
        }
        return source;
    }

注意看注释,说明了这是一个hook方法,可以看到直接return的说是传入进来的source,所以,我们可以得出,Single.just(item)就相当于new SingleJust<T>(item)

订阅过程

再来看.subscribe(new SingleObserver<Integer>)的源码

   @SchedulerSupport(SchedulerSupport.NONE)
    @Override
    public final void subscribe(SingleObserver<? super T> observer) {
   
        //判空
        ObjectHelper.requireNonNull(observer, "observer is null");

        //HOOK
        observer = RxJavaPlugins.onSubscribe(this, observer);

        //继续判空
        ObjectHelper.requireNonNull(observer, "The RxJavaPlugins.onSubscribe hook returned a null SingleObserver. Please check the handler provided to RxJavaPlugins.setOnSingleSubscribe for invalid null returns. Further reading: https://github.com/ReactiveX/RxJava/wiki/Plugins");

        try {
   
            //执行当前类的subscribeActual
            subscribeActual(observer);
        } catch (NullPointerException ex) {
   
            throw ex;
        } catch (Throwable ex) {
   
            Exceptions.throwIfFatal(ex);
            NullPointerException npe = new NullPointerException("subscribeActual failed");
            npe.initCause(ex);
            throw npe;
        }
    }

代码里有做注释,其实真正调用的方法是subscribeActual(observer);方法

protected abstract void subscribeActual(@NonNull SingleObserver<? super T> observer);

可以发现,这是一个抽象方法,那么我们要找到它的实现。

我们回到来看上面的方法其实可以发现,Single.just()调用的subscribe,而Single.just我们在上面讲到,就相当于new SingleJust(),所以我们只要看SingleJust里的subscribeActual方法就可以了。

public final class SingleJust<T> extends Single<T> {
   

    final T value;

    public SingleJust(T value) {
   
        this.value = value;
    }

    @Override
    protected void subscribeActual(SingleObserver<? super T> observer) {
   
        observer.onSubscribe(Disposables.disposed());
        observer.onSuccess(value);
    }

}

这个类超级简单,就是把上游的事件发送到下游SingleObserver,比如我们在实例中,Single.just(1)就相当于new SingleJust(1),所以在这儿,value=1,然后调用subscribeActual方法,SingleObserver是一个接口,有三个方法,也是我们回调里的三个方法

public interface SingleObserver<T> {
   
    void onSubscribe(@NonNull Disposable d);

    void onSuccess(@NonNull T t);

    void onError(@NonNull Throwable e);
}

在subscribeActual方法中,先observer.onSubscribe(Disposables.disposed());,需要注意的是,这也是just方法独有的,它直接在onSubscribe方法里就Disposables.disposed了,这个方法在后面讲,这是取消了事件订阅,因为它只会发一次,到了这就意味着已经不用订阅了。然后再调用observer.onSuccess方法,直接把value传递了过去。

Map操作符的源码

再来看增加一个操作符的源码,就用最常用的map,其实操作符一通百通

		Single.just(1)
                .map(new Function<Integer, Integer>() {
   
                    @Override
                    public Integer apply(Integer integer) throws Exception {
   
                        return integer+2;
                    }
                })
                .subscribe(...);

直接看map的源码

    public final <R> Single<R> map(Function<? super T, ? extends R> mapper) {
   
        //判空
        ObjectHelper.requireNonNull(mapper, "mapper is null");
        //hook,就相当于new SingleMap
        return RxJavaPlugins.onAssembly(new SingleMap<T, R>(this, mapper));
    }

可以看到,这就相当于new SingleMap(this,mapper);返回值依然是Single

我们看SingleMap的源码

public final class SingleMap<T, R> extends Single<R> {
   
    final SingleSource<? extends T> source;

    final Function<? super T, ? extends R> mapper;

    public SingleMap(SingleSource<? extends T> source, Function<? super T, ? extends R> mapper) {
   
        //这就是刚刚传进来的this,也就是上游的被观察者
        this.source = source;
        //这是我们自己在map中写的new function方法
        this.mapper = mapper;
    }

    //由上文subscribe方法分析可知,当调用subscribe时,这个回调是会被调用的
    @Override
    protected void subscribeActual(final SingleObserver<? super R> t) {
   
        //可以看到,就是相当于是把上游的被观察者source,直接调用了它的subscribe方法
        //我们主要的精力只要集中看new MapSingleObserver方法就行
        source.subscribe(new MapSingleObserver<T, R>(t, mapper));
    }

    //此observer观察者中,把处理后的数据都传递给了下游,但是,只提供了事件的流向,因为事件是在上游产生的
    static final class MapSingleObserver<T, R> implements SingleObserver<T> {
   

        final SingleObserver<? super R> t;

        final Function<? super T, ? extends R> mapper;

        MapSingleObserver(SingleObserver<? super R> t, Function<? super T, ? extends R> mapper) {
   
            this.t = t;
            this.mapper = mapper;
        }

        @Override
        public void onSubscribe(Disposable d
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值