RxJava GitHub主页: https://github.com/ReactiveX/RxJava
RxJava是Netflix推出的一个基于JVM的Microsoft Reactive Extensions 扩展,提供Java, Scala, Clojure, 和 Groovy语言实现,Netflix也是美国很牛X的一个公司,《纸牌屋》就是该公司的自制剧之一,这是题外话,我们看一下 RxJava在 GitHub 主页上的简介。
RxJava is a Java VM implementation of [Reactive Extensions]( http://reactivex.io ): a library for composing asynchronous and event-based programs by using observable sequences.
It extends the [observer pattern]( http://en.wikipedia.org/wiki/Observer_pattern ) to support sequences of data/events and adds operators that allow you to compose sequences together declaratively while abstracting away concerns about things like low-level threading, synchronization, thread-safety and concurrent data structures.
RxJava是一个在 Java VM 上使用可观测的序列来组成异步的、基于事件的程序的库。它采用观察者模式来支持数据/事件的序列,增加了操作符,允许以声明的方式(链式语法)将异步操作序列组合在一起。
Reactive Extensions (Rx) 最初是由微软在.Net中实现的一个综合了异步和基于事件驱动编程的库包。开发者可以用Observables来表达异步数据流,使用LinQ操作查询异步数据流,使用Schedulers参数化异步数据流中并发。2012年Netflix为了应对不断增长的业务需求开始将.NET Rx迁移到JVM上面。并于2013年2月份正式向外展示了RxJava。
除了RxJava和Rx .Net,基于Rx还有许多其它项目如RxJS、RxCpp、RxPy等等。
RxJava简单的说它就是一个Java中处理异步任务的库,允许我们用简介的语法操作复杂的异步业务逻辑。
RxJava流行的主要原因都要归于它处理异步任务逻辑的简洁。从上面我们也知道它的主要目的也是用于处理异步任务。在Android中谷歌官方为了处理异步业务提供了两个类AsyncTask 和Handler,在RxJava没有流行之间,如果不想使用这两个类,开发者要自定义一个回调来更新UI。可能有些开发者说了,不使用这两个类,还有更简单的方式runOnUiThread,事实上runOnUiThread也是使用的Handler机制实现的。即使这个不说我们在从网络获取数据的时候,也都要开启一个子线程才能发起网络请求。如果我们使用RxAndroid来实现这个操作,就简洁许多了。
Observable.create(new Observable.OnSubscribe<String>() { @Override public void call(Subscriber<? super String> subscriber) { //子线程发起网络请求 String result = HttpUtils.getInstance().get(url); subscriber.onNext(result); } }).observeOn(AndroidSchedulers.mainThread()).subscribeOn(Schedulers.io()).subscribe(new Subscriber<String>() { @Override public void onCompleted() { } @Override public void onError(Throwable e) { } @Override public void onNext(String s) { //主线程更新UI textView.setText(s); } });
有没有这种感觉,所有的业务操作一气呵成。RxJava采用链式语法,结构上看上去非常优雅,允许用户连续设计各种行为,从而实现按人的惯性思维进行快速开发。接触过jQuery的开发者,多数都会被jQuery中链式调用的优雅所折服,现在RxJava也是采用了链式语法,不得不说这也是它可以风靡的主要原因之一。
RxJava提供了丰富的操作符,如果现有的操作符满足不了需求,还可以自定义操作符。下面操作符节选自知乎中 谁来讲讲Rxjava、rxandroid中的操作符的作用? 的回答:
因为记录笔记,操作符就罗列出来了。实际开发中不需要都记住,掌握常用的几个(如,just, map,flatMap和filter等等),其它的使用时查阅文档即可,用几次自然就掌握了。
下面是利用操作符遍历输出一个二维数组,这里就可以看出RxJava操作符的便利之处了。
String array[][]={{"a0","a1"},{"b0","b1"},{"c0","c1","c2"}}; Observable.from(array).flatMap(new Func1<String [], Observable<String>>() { @Override public Observable<String> call(String[] t) { return Observable.from(t); } }).subscribe(new Action1<String>() { @Override public void call(String t) { System.out.println(t); } });
Observable.create(new OnSubscribe<String>() { @Override public void call(Subscriber<? super String> subscriber) { subscriber.onNext("hello world!"); subscriber.onCompleted(); } }).subscribe(new Subscriber<String>() { @Override public void onNext(String t) { System.out.println("onNext:"+t); } @Override public void onCompleted() { System.out.println("onCompleted"); } @Override public void onError(Throwable e) { } });
//订阅者 Subscriber<String> subscriber=new Subscriber<String>() { @Override public void onNext(String t) { System.out.println(t);//小二上酒! } @Override public void onError(Throwable e) { } @Override public void onCompleted() { System.out.println("onCompleted"); } }; //被观察者 Observable<String> observable=Observable.create(new OnSubscribe<String>() { @Override public void call(Subscriber<? super String> subscriber) { subscriber.onNext("小二上酒!"); subscriber.onCompleted(); } }); observable.subscribe(subscriber);
如果自定义实现RxJava入门这种调用方式,OnSubscribe是一个关键所在,它是连接观察者(订阅者)与被观察者的一个纽带。
Onsubscribe是一个接口,接口中有一个call方法,将Observer观察者(订阅者)作为入参传入,Observer就可以在call方法中将数据回调出去,然后再在Observable调用subscribe方法时实例化Observer,就可以获得call方法中相应的数据了。
Observable代码如下:
public class Observable<T> { final OnSubscribe<T> onSubscribe; protected Observable(OnSubscribe<T> f) { this.onSubscribe = f; } public static <T> Observable<T> create(OnSubscribe<T> f) { return new Observable<T>(f); } public final void subscribe(Observer<T> observer) { onSubscribe.call(observer); } public interface OnSubscribe<T> extends Action<Observer<T>> { } } //Action public interface Action<T> { void call(T t); }
Observer源码如下:
public interface Observer<T> { void onUpdate(T t); }
测试代码如下:
//链式调用 Observable.create(new OnSubscribe<String>() { @Override public void call(Observer<String> observer) { observer.onUpdate("hello world"); } }).subscribe(new Observer<String>() { @Override public void onUpdate(String t) { System.out.println(t);//hello world } }); //非链式调用 Observable<String> observable=Observable.create(new OnSubscribe<String>() { @Override public void call(Observer<String> observer) { observer.onUpdate("hello world"); } }); Observer<String> observer=new Observer<String>(){ @Override public void onUpdate(String t) { System.out.println(t);//hello world } } ; observable.subscribe(observer);
本篇博客基本上就是一个学习RxJava的引言,当然了在正式学习RxJava之前有必要熟悉一下观察者模式。有关操作符的使用以及针对Android开发的RxAndroid准备另起一篇博客记录一下。也许本文的示例太过简单,没有很强的说服力,如果想系统学习一下RxJava,可以在GitHub上下载下来的示例对比着宝石图运行一下。每一个操作符都配备了一张宝石图,它对事件处理时的顺序、方式以及什么时候结束描述的非常直观。