python和深度学习半栈工程师首页投稿(暂停使用,暂停投稿)

RxJava2.0另类理解:干细胞的进化之路

2017-09-08  本文已影响0人  量子Magic

(本文基于rxjava2.0/rxandroid2.0而写)

RxJava很神奇!很神奇不是指它在GitHub上写的“A library for composing asynchronous and event-based programs by using observable sequences.”,而是它的设计模型很神奇。

我解析了它的源码,发现RxJava竟然是类似干细胞进化。

RxJava的干细胞模型

RxJava的干细胞模型很简单,本质上是基于观察者模式的扩展,先上类图。

主类示意图

一个被观察者虚类Observable,实现它必须实现subscribeActual,一个观察者接口类Observer,它扩展了一些接口。OK,我们看看这个简单的结构,能干点什么。

首先,实现一个简单的Observable和Observer:

public class AObservable extends Observable<Integer>{

 @Override
 protected void subscribeActual(Observer<? super Integer> observer) {
 int a = 1+2;

 observer.onNext(a);
 observer.onComplete();
 }
}

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

 }

 @Override
 public void onNext(Integer value) {
 System.out.println(value);
 }

 @Override
 public void onError(Throwable e) {

 }

 @Override
 public void onComplete() {
 System.out.println("End!");
 }
});

Observable做了两件事,计算1+2的结果,返回给Observer,Observer接收到结果后,打印了出来。在这里,Observable负责处理事情,Observer负责接收处理结果,就这么简单。这时候,你可能开始疑惑,就只能做这么一件事情?

当然不是!

Observable进化和相互作用

生物的干细胞能根据不同的需求,进化成肌细胞、血红细胞、脑细胞等等,Observable也不例外,通过继承,能实现不同的功能等Observable,而且RxJava库已经帮你实现了大量的Observable,你只需要简单地调用就行。

另外,进化后的细胞相互作用后,会形成各种各样的生理机能,Observable也是如此。想想,当BObservable给AObservable提供Observer的时候,会发生什么事?我们来看一个有趣的例子。

Observable.just(1, 2, 3,4 )
 .map(new Function<Integer, String>() {
 @Override
 public String apply(Integer integer) throws Exception {
 return "Hello, "+integer;
 }
 })
 .subscribe(new Consumer<String>() {
 @Override
 public void accept(String s) throws Exception {
 System.out.println(s);
 }
 });

just(1, 2, 3,4 )实现了一个ObservableFromArray的Observable对象,map(...)实现了一个ObservableMap的Observable对象,并且在它的subscribeActual里面给ObservableFromArray提供了Observer。这样子,你就看到这样子的场景,ObservableFromArray把1234形成整型数组,挨个传给了ObservableMap,ObservableMap把整型数组挨个转成"Hello, x"后,传给它的Observer,打印出来。

你可以这样子随意地拼接能提供Observer的Observable,形成复杂的任务链。怎么样,是不是很神奇?RxJava可不是仅限于这种简单的拼接交互,不过更多的交互得你自己去挖掘了。

好了,我们来看一个更加神奇的进化。

进一步进化

RxJava有两个特殊的Observer,ObservableObserveOn和ObservableSubscribeOn,里面都包含了Scheduler,用于控制任务执行的线程。

下面,我们来看看源码,先看ObservableObserveOn。

public ObservableObserveOn(ObservableSource<T> source, Scheduler scheduler, boolean delayError, int bufferSize)

@Override
protected void subscribeActual(Observer<? super T> observer) {
 if (scheduler instanceof TrampolineScheduler) {
 source.subscribe(observer);
 } else {
 Scheduler.Worker w = scheduler.createWorker();

 source.subscribe(new ObserveOnObserver<T>(observer, w, delayError, bufferSize));
 }
}

ObservableObserveOn实现了一个观察者ObserveOnObserver,这个观察者关联了ObservableObserveOn的观察者,即subscribeActual传入参数Observer<? super T> observer,和Scheduler.Worker,Scheduler.Worker会把observer的监听函数放入到Scheduler创建的线程中运行。

再看ObservableSubscribeOn。

@Override
public void subscribeActual(final Observer<? super T> s) {
 final SubscribeOnObserver<T> parent = new SubscribeOnObserver<T>(s);

 s.onSubscribe(parent);

 parent.setDisposable(scheduler.scheduleDirect(new Runnable() {
 @Override
 public void run() {
 source.subscribe(parent);
 }
 }));
}

scheduler直接把 source.subscribe(parent);放到新的线程中执行,实现对source的subscribeActual线程控制,因为subcribe会执行subcribeActual。

更多的Observable或者Flowable(支持Backpressure的Observable),查看源码。

一个使用示例

Observable.just("one", "two", "three", "four", "five")
 .subscribeOn(Schedulers.newThread())
 .observeOn(AndroidSchedulers.mainThread())
 .subscribe(new Consumer<String>() {
 @Override
 public void accept(String s) throws Exception {
 System.out.println(s);
 }
 });

这个示例创建了3个Observable,just("one", "two", "three", "four", "five")创建了ObservableFromArray,用于把数组中的子项一个个输出,subscribeOn(Schedulers.newThread())创建了ObservableSubscribeOn,用于控制ObservableFromArray的subscribe的执行线程,observeOn(AndroidSchedulers.mainThread())创建了ObservableObserveOn,用来控制接下来的Observe的监听线程。

看完,相信大家对 Rxjava的机制和用法都有了很直观的认识!

上一篇下一篇

猜你喜欢

热点阅读