rxjava2基本元素源码分析

无背压

代码示例

Observable.create(new ObservableOnSubscribe() {
    @Override
    public void subscribe(ObservableEmitter emitter) throws Exception {
        LogUtils.loge("Observable onSubscribe subscribe...");
        if (!emitter.isDisposed()) {
            emitter.onNext("test1");
            emitter.onComplete();
        }
    }
}).subscribe(new Observer() {
    @Override
    public void onSubscribe(Disposable d) {
        LogUtils.loge("Observer onSubscribe ...");
    }

    @Override
    public void onNext(String s) {
        LogUtils.loge("Observer onNext str = " + s);
    }

    @Override
    public void onError(Throwable e) {

    }

    @Override
    public void onComplete() {
        LogUtils.loge("Observer onComplete ...");
    }
});

基本元素

Observable

  1. 观察得到的-被观察者,不支持背压
  2. 通过Observable创建一个可观察的序列(create)
  3. 通过subscribe去注册一个观察者

Observer

  1. 用于接收数据----观察者
  2. 作为Observable的subscribe的方法的参数

Disposable

  1. 和Rxjava1的Susbscription的作用相当
  2. 用于取消订阅和获取当前的订阅状态

ObservableOnSubscribe

  1. 当订阅时会触发此接口调用
  2. 在Observable内部,实际作用是向观察者发射数据

Emitter

  1. 一个发送数据的接口,和Observer的方法类似
  2. 本质是对Observer和Subscriber的包装

流程分解

io.reactivex.Observable#create

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

io.reactivex.plugins.RxJavaPlugins#onAssembly(io.reactivex.Observable)

public static  Observable onAssembly(@NonNull Observable source) {
    Function f = onObservableAssembly;
    // onObservableAssembly为里为空,所以f为空。返回的是我们传入的observable
    if (f != null) {
        return apply(f, source);
    }
    return source;
}

io.reactivex.Observable#subscribe(io.reactivex.Observer)

@SchedulerSupport(SchedulerSupport.NONE)
@Override
public final void subscribe(Observer observer) {
    ObjectHelper.requireNonNull(observer, "observer is null");
    try {
        observer = RxJavaPlugins.onSubscribe(this, observer);
        // 这里实际上是调用的是ObservableCreate中的subscribeActual方法
        subscribeActual(observer);
    } catch (NullPointerException e) { // NOPMD
    } catch (Throwable e) {
    }
}

io.reactivex.plugins.RxJavaPlugins#onSubscribe(io.reactivex.Observable, io.reactivex.Observer)####

public static  Observer onSubscribe(@NonNull Observable source, @NonNull Observer observer) {
    BiFunction f = onObservableSubscribe;
    // onObservableSubscribe,所以f为空。返回的是我们传入的observer
    if (f != null) {
        return apply(f, source, observer);
    }
    return observer;
}

io.reactivex.internal.operators.observable.ObservableCreate

@Override
protected void subscribeActual(Observer observer) {
    // 构建Emitter
    CreateEmitter parent = new CreateEmitter(observer);
    // 调用observer的onSubscribe,并传入创建的Emitter
    observer.onSubscribe(parent);

    try {
        // 调用subscribe方法
        source.subscribe(parent);
    } catch (Throwable ex) {
        Exceptions.throwIfFatal(ex);
        parent.onError(ex);
    }
}

@Override
public boolean isDisposed() {
    return emitter.isDisposed();
}

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 (!isDisposed()) {
            observer.onNext(t);
        }
    }

    @Override
    public void onComplete() {
        if (!isDisposed()) {
            try {
                observer.onComplete();
            } finally {
                dispose();
            }
        }
    }

    @Override
    public void dispose() {
        DisposableHelper.dispose(this);
    }

    @Override
    public boolean isDisposed() {
        return DisposableHelper.isDisposed(get());
    }
}

io.reactivex.internal.disposables.DisposableHelper 单例类

public enum DisposableHelper implements Disposable {

    DISPOSED
    ;

    public static boolean isDisposed(Disposable d) {
        // 判断需要dispose的对象是否是已经dispose的
        return d == DISPOSED;
    }

    public static boolean dispose(AtomicReference field) {
        / 取到当前的Disposable的对象
        Disposable current = field.get();
        // 得到已经disposed的对象
        Disposable d = DISPOSED;
        if (current != d) {
            // 将AtomicReference中Disposable标识为disposed状态
            current = field.getAndSet(d);
            if (current != d) {
                if (current != null) {
                    current.dispose();
                }
                return true;
            }
        }
        return false;
    }

    @Override
    public boolean isDisposed() {
        return true;
    }
}

有背压

代码示例

    Flowable.create((FlowableOnSubscribe) emitter -> {
        LogUtils.loge("FlowableOnSubscribe subscribe");
        if (!emitter.isCancelled()) {
            emitter.onNext("test11");
            emitter.onComplete();
        }
    }, BackpressureStrategy.DROP).subscribe(new Subscriber() {
        @Override
        public void onSubscribe(Subscription s) {
            // 需要主动发起请求否则会请求不到数据
            s.request(Integer.MAX_VALUE);
            LogUtils.loge("Subscriber onSubscribe");
        }

        @Override
        public void onNext(String s) {
            LogUtils.loge("Subscriber onNext s = " + s);
        }

        @Override
        public void onError(Throwable t) {

        }

        @Override
        public void onComplete() {
            LogUtils.loge("Subscriber onComplete");
        }
    });

基本元素

Flowable

  1. 易流动的--------被观察者,支持背压
  2. 通过Flowable创建一个可观察的序列(create方法)
  3. 通过subscribe去注册一个观察者

Subscriber

  1. 一个单独接口,和Observer方法类似
  2. 作为Flowable的subscribe方法的一个参数

Subscription

  1. 订阅,和Rxjava1有所不同
  2. 支持背压,有用于背压的request方法

FlowableOnSubscribe

  1. 当订阅时会触发此接口调用
  2. 在Flowable内部,实际作用是向观察者发射数据

OnSubscribe

Emitter

  1. 一个发射数据的接口,和Observer的方法类似
  2. 本质是对Observer和Subscriber的包装

流程分解

io.reactivex.Flowable#create

public static  Flowable create(FlowableOnSubscribe source, BackpressureStrategy mode) {
    // 这里返回的就是FlowableCreate
    return RxJavaPlugins.onAssembly(new FlowableCreate(source, mode));
}

io.reactivex.Flowable#subscribe(org.reactivestreams.Subscriber)

public final void subscribe(Subscriber s) {
    subscribe(new StrictSubscriber(s));
}

io.reactivex.Flowable#subscribe(io.reactivex.FlowableSubscriber)

public final void subscribe(FlowableSubscriber s) {
    Subscriber z = RxJavaPlugins.onSubscribe(this, s);
    // 调用的是FlowableCreate的subscribeActual方法
    subscribeActual(z);
}

io.reactivex.internal.operators.flowable.FlowableCreate

@Override
public void subscribeActual(Subscriber t) {
    BaseEmitter emitter;
    // 根据背压策略构建emitter
    switch (backpressure) {
        case MISSING: {
            emitter = new MissingEmitter(t);
            break;
        }
        case ERROR: {
            emitter = new ErrorAsyncEmitter(t);
            break;
        }
        case DROP: {
            emitter = new DropAsyncEmitter(t);
            break;
        }
        case LATEST: {
            emitter = new LatestAsyncEmitter(t);
            break;
        }
        default: {
            emitter = new BufferAsyncEmitter(t, bufferSize());
            break;
        }
    }
    // 调用   Subscriber的onSubscribe
    t.onSubscribe(emitter);
    try {
        // 调用subscribe方法
        source.subscribe(emitter);
    } catch (Throwable ex) {
        Exceptions.throwIfFatal(ex);
        emitter.onError(ex);
    }
}

io.reactivex.internal.operators.flowable.FlowableCreate#DropAsyncEmitter

static final class DropAsyncEmitter extends NoOverflowBaseAsyncEmitter {

    private static final long serialVersionUID = 8360058422307496563L;

    DropAsyncEmitter(Subscriber downstream) {
        super(downstream);
    }
}

io.reactivex.internal.operators.flowable.FlowableCreate#NoOverflowBaseAsyncEmitter

abstract static class NoOverflowBaseAsyncEmitter extends BaseEmitter {

    private static final long serialVersionUID = 4127754106204442833L;

    NoOverflowBaseAsyncEmitter(Subscriber downstream) {
        super(downstream);
    }

    @Override
    public final void onNext(T t) {
        if (isCancelled()) {
            return;
        }
        
        // get的值不为0才会调用onNext方法
        // 只有调用了request(n)的时候,这里才不会为0
        if (get() != 0) {
            downstream.onNext(t);
            BackpressureHelper.produced(this, 1);
        } else {
            onOverflow();
        }
    }

    abstract void onOverflow();
}

io.reactivex.internal.operators.flowable.FlowableCreate#BaseEmitter

abstract static class BaseEmitter
extends AtomicLong
implements FlowableEmitter, Subscription {
    private static final long serialVersionUID = 7326289992464377023L;

    final Subscriber downstream;

    final SequentialDisposable serial;

    BaseEmitter(Subscriber downstream) {
        this.downstream = downstream;
        this.serial = new SequentialDisposable();
    }

    @Override
    public final void cancel() {
        serial.dispose();
        onUnsubscribed();
    }

    @Override
    public final boolean isCancelled() {
        return serial.isDisposed();
    }

    @Override
    public final void request(long n) {
        if (SubscriptionHelper.validate(n)) {
            BackpressureHelper.add(this, n);
        }
    }
}

io.reactivex.internal.subscriptions.SubscriptionHelper#validate(long)

public static boolean validate(long n) {
    /* 如果传入的值小于等于0的时候,就直接返回了, 这就是为啥不调用这个request方法,onNext方法是不走的
    */
    if (n <= 0) {
        RxJavaPlugins.onError(new IllegalArgumentException("n > 0 required but it was " + n));
        return false;
    }
    return true;
}

io.reactivex.internal.util.BackpressureHelper#add

public static long add(AtomicLong requested, long n) {
    for (;;) {
        long r = requested.get();
        if (r == Long.MAX_VALUE) {
            return Long.MAX_VALUE;
        }
        long u = addCap(r, n);
        // requested的这里会被设置成最大值
        if (requested.compareAndSet(r, u)) {
            return r;
        }
    }
}

io.reactivex.internal.util.BackpressureHelper#produced

public static long produced(AtomicLong requested, long n) {
    for (;;) {
        long current = requested.get();
        if (current == Long.MAX_VALUE) {
            return Long.MAX_VALUE;
        }
        long update = current - n;
        if (update < 0L) {
            RxJavaPlugins.onError(new IllegalStateException("More produced than requested: " + update));
            update = 0L;
        }
        if (requested.compareAndSet(current, update)) {
            return update;
        }
    }
}

源码阅读总结

不调用request,onNext不被执行的原因分析

Subscriber->onSubscribe

s.request(Integer.MAX_VALUE);

FlowableCreate.BaseEmitter#request ->

io.reactivex.internal.util.BackpressureHelper#add

将设置的值更新到BaseEmitter中,BaseEmitter继承自AtomicLong


FlowableOnSubscribe-> subscribe
emitter.onNext(a);

io.reactivex.internal.operators.flowable.FlowableCreate.NoOverflowBaseAsyncEmitter#onNext

获取AtomicLong的值,不为0的时候,才会调用Subscriber的onNext方法

总之,Flowable是复用强制拉取,解决背压策略的

你可能感兴趣的:(rxjava2基本元素源码分析)