目录
4.延伸:利用subscribeOn() 指定doOnSubscribe()执行线程
RxJava 默认事件的产生和消费都是在同一个线程的。也就是说,默认实现的只是一个同步的观察者模式,即:在哪个线程调用 subscribe()(订阅),就在哪个线程生产事件;在哪个线程生产事件,就在哪个线程消费事件,此时数据发送和数据接收是一一对应的,即发送一个,接收一个,再发送一个,再接收一个……。如果需要切换线程,就需要用到 Scheduler (调度器),它可以让RxJava的线程切换变得简单明了,轻松实现异步。
1.Scheduler 类型
Scheduler:线程控制器 / 调度器,RxJava 通过它来指定每一段代码应该运行在什么样的线程。RxJava内置几种 Scheduler 类型,基本适合大多数的使用场景:
(1)Schedulers.newThread(): 总是启用新线程,并在新线程执行操作。
(2)Schedulers.io():
用于IO密集型的操作,例如读写SD卡文件,查询数据库,网络信息交互等,具有线程缓存机制。行为模式和 newThread() 差不多,区别在于 io() 的内部实现是是用一个无数量上限的线程池,可以重用空闲的线程。调度器接收到任务后,先检查线程缓存池中,如果有空闲的线程,则复用,否则创建新的线程,并加入到线程池中,如果每次都没有空闲线程使用,可以无上限的创建新线程。因此多数情况下 io() 比 newThread() 更有效率。不要把计算工作放在 io() 中,可以避免创建不必要的线程。
(3)Schedulers.computation(): 计算所使用的 Scheduler。这个计算指的是 CPU 密集型计算,即