RxJava 1.x 理解-2

给RxJava 加入线程控制 -- Scheduler

在 RxJava 1.x 理解-1 中,咱们说到了RxJava的简单用法,可是这还远远不够,由于这简单用法是在同一个线程中使用的。好比咱们须要在子线程中进行耗时操做,在Android 主线程中进行UI操做,这样才不会致使卡顿的发生。html

先上代码:java

        Observable
                .create(new Observable.OnSubscribe<String>() {
                    @Override
                    public void call(Subscriber<? super String> subscriber) {
                        subscriber.onNext("提供数据01 获取线程id:" + Thread.currentThread().getId());
                        subscriber.onNext("提供数据02 获取线程id:" + Thread.currentThread().getId());
                        subscriber.onNext("提供数据03 获取线程id:" + Thread.currentThread().getId());
                        subscriber.onNext("提供数据04 获取线程id:" + Thread.currentThread().getId());
                    }
                })
                .subscribeOn(Schedulers.io())              // 订阅发生在   // 指定 subscribe() 发生在 IO 线程   
                .observeOn(AndroidSchedulers.mainThread()) // 观察发生在   // 指定 Subscriber 的回调发生在主线程 
                .subscribe(new Action1<String>() {
                    @Override
                    public void call(String s) {
                        Log.d(TAG, "Item: " + s + " 执行调用 获取线程id:" + Thread.currentThread().getId());
                    }
                });

输入的结果:数据库

02-08 22:19:04.212 6071-6071/pers.bolin.rxjavademo D/MainActivity: Item: 提供数据01 获取线程id:6091 / 执行调用 获取线程id:2
02-08 22:19:04.212 6071-6071/pers.bolin.rxjavademo D/MainActivity: Item: 提供数据02 获取线程id:6091 / 执行调用 获取线程id:2
02-08 22:19:04.212 6071-6071/pers.bolin.rxjavademo D/MainActivity: Item: 提供数据03 获取线程id:6091 / 执行调用 获取线程id:2
02-08 22:19:04.212 6071-6071/pers.bolin.rxjavademo D/MainActivity: Item: 提供数据04 获取线程id:6091 / 执行调用 获取线程id:2

能够看出提供数据的事件发生在IO线程中,而回调的事件发生在主线程中了。网络

在RxJava 中,Scheduler ——调度器,至关于线程控制器,RxJava 经过它来指定每一段代码应该运行在什么样的线程。RxJava 已经内置了几个 Scheduler ,它们已经适合大多数的使用场景:ide

  • Schedulers.immediate(): 直接在当前线程运行,至关于不指定线程。这是默认的 Scheduler
  • Schedulers.newThread(): 老是启用新线程,并在新线程执行操做。
  • Schedulers.io(): I/O 操做(读写文件、读写数据库、网络信息交互等)所使用的 Scheduler。行为模式和 newThread() 差很少,区别在于 io() 的内部实现是是用一个无数量上限的线程池,能够重用空闲的线程,所以多数状况下 io() 比 newThread() 更有效率。不要把计算工做放在 io() 中,能够避免建立没必要要的线程。
  • Schedulers.computation(): 计算所使用的 Scheduler。这个计算指的是 CPU 密集型计算,即不会被 I/O 等操做限制性能的操做,例如图形的计算。这个 Scheduler 使用的固定的线程池,大小为 CPU 核数。不要把 I/O 操做放在 computation() 中,不然 I/O 操做的等待时间会浪费 CPU。
  • 另外, Android 还有一个专用的 AndroidSchedulers.mainThread(),它指定的操做将在 Android 主线程运行。

有了这几个 Scheduler ,就可使用 subscribeOn() 和 observeOn() 两个方法来对线程进行控制了。 * subscribeOn(): 指定 subscribe() 所发生的线程,即 Observable.OnSubscribe 被激活时所处的线程。或者叫作事件产生的线程。 * observeOn(): 指定 Subscriber 所运行在的线程。或者叫作事件消费的线程。post

 

参考资料:性能

一块儿来造一个RxJava,揭秘RxJava的实现原理url

给 Android 开发者的 RxJava 详解spa

相关文章
相关标签/搜索