rxjava-android 模块包含RxJava的Android特定的绑定代码。它给RxJava添加了一些类,用于帮助在Android应用中编写响应式(reactive)的组件。
rxjava-android
reactive
Handler
Observable
Scheduler
Fragment
Activity
你可以在 http://search.maven.org 找到用于Maven, Ivy, Gradle和其它构建系统的二进制文件和依赖信息。
Maven 示例:
<dependency> <groupId>io.reactivex</groupId> <artifactId>rxandroid</artifactId> <version>0.23.0</version> </dependency>
Ivy 示例:
<dependency org="io.reactivex" name="rxandroid" rev="0.23.0" />
当前支持的最低API版本(minSdkVersion)是 10 (Android 2.3/Gingerbread)
minSdkVersion
10
在Android上,通常处理异步任务时你会在主线程上等待(observing)处理结果,一般情况下你使用 AsyncTask 达到这个目的。使用RxJava,你会使用 observeOn 操作符声明你要在主线程等待 Observable 的结果:
AsyncTask
observeOn
public class ReactiveFragment extends Fragment { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Observable.from("one", "two", "three", "four", "five") .subscribeOn(Schedulers.newThread()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(/* an Observer */); }
这个例子中,Observable在一个新的线程执行,结果通过 onNext 在主线程发射。
onNext
前面的例子是一个普遍概念的特殊版本:Android使用一个叫 Handler 的类绑定异步通信到消息循环。为了在任意线程 观察 一个Observable,需要创建一个与那个类关联的 Handler,然后使用 AndroidSchedulers.handlerThread 调度器:
观察
AndroidSchedulers.handlerThread
new Thread(new Runnable() { @Override public void run() { final Handler handler = new Handler(); // bound to this thread Observable.from("one", "two", "three", "four", "five") .subscribeOn(Schedulers.newThread()) .observeOn(AndroidSchedulers.handlerThread(handler)) .subscribe(/* an Observer */) // perform work, ... } }, "custom-thread-1").start();
这个例子中,Observable在一个新的线程执行,结果通过 onNext 在 custom-thread-1 线程上发射。(这个例子不太自然,因为你可以调用observeOn(Schedulers.currentThread()),但是它说清楚了这个想法。)
custom-thread-1
observeOn(Schedulers.currentThread())
在Android上,要在异步操作中访问框架中的对象有些棘手,那是因为Andoid系统可以决定销毁(destroy)一个 Activity,例如,当一个后台线程还在运行的时候,如果这个线程尝试访问一个已经死掉的Activity中的View对象,会导致异常退出(Crash)。(这也会导致内存泄露,因为 Activity 已经不可见了,你的后台线程还持有它的引用。)
destroy
这仍然是在Android上使用RxJava需要关注的一个问题,但是通过使用 Subscription和其它Observable操作符,你可以优雅地解决这个问题。通常来说,当你在Activity中订阅一个Observable的结果时(无论是直接的还是通过一个内部类),你必须在 onDestroy 里取消订阅,就像下面例子里展示的那样:
Subscription
onDestroy
// MyActivity private Subscription subscription; protected void onCreate(Bundle savedInstanceState) { this.subscription = observable.subscribe(this); } ... protected void onDestroy() { this.subscription.unsubscribe(); super.onDestroy(); }
这样确保所有指向订阅者(这个Activity)的引用尽快释放,不会再有通知通过 onNext 发射给这个订阅者。
有一个问题,如果由于屏幕方向的变化导致这个 Activity 被销毁,在 onCreate 中这个Observable会再次启动。你可以使用 cache 或 replay 操作符阻止它发生,这些操作符保证Observable在 Activity 的生命周期内存在(你可以在一个全局的缓存中保存它,比如放在Fragment中。)你可以使用任何操作符,只要能保证:当订阅者订阅一个已经在运行的Observable时,在它与Activity 解除关联的这段时间里发射的数据都会被回放,并且来自这个Observable的任何离线通知都会正常分发。
onCreate
cache
replay
回放
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8