RxJava 线程池

线程控制——Scheduler

RxJava中的多线程操作主要是由Scheduler集合提供的。在RxJava中,我们无法直接访问或操作线程。如果想要使用线程的话,必须要通过内置的Scheduler来实现。

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

    

rxjava io线程安全 rxjava 线程池_线程池

  • Schedulers.io():它适用于非CPU密集的I/O工作,比如访问文件系统、执行网络调用、访问数据库等等。这个Scheduler是没有限制的,它的线程池可以按需一直增长。不要把计算工作放在 io() 中,可以避免创建不必要的线程。
  • Schedulers.computation():这个Scheduler用于执行CPU密集的工作,比如处理大规模的数据集、图像处理等等。它由一个有界的线程池作为支撑,线程的最大数量就是可用的处理器数量。
    因为这个Scheduler只适用于CPU密集的任务,我们希望限制线程的数量,这样的话,它们不会彼此抢占CPU时间或出现线程饿死的现象。
  • Schedulers.newThread():总是启用新线程,并在新线程执行操作。
  • Schedulers.single():此款调度器非常简单,由一个线程支持。所以无论有多少个observables,都将只运行在这个线程上。也可将其认为是主线程的一个替代。
  • Schedulers.trampoline():在当前线程立即执行任务,如果当前线程有任务在执行,则会将其暂停,等插入进来的任务执行完之后,再将未完成的任务接着执行。
  • Schedulers.from(Executor executor):我们可以使用它创建自定义的Scheduler,它是由我们自己的Executor作为支撑的。在有些场景下,我们希望创建自定义的Scheduler为App执行特定的任务,这些任务可能需要自定义的线程逻辑。

AndroidSchedulers.mainThread()

这是一个特殊的Scheduler,它无法在核心RxJava库中使用,要使用它,必须要借助RxAndroid扩展库。这个Scheduler对Android App特别有用,它能够在应用的主线程中执行基于UI的任务。

/* 异步任务引用包*/ implementation 'io.reactivex.rxjava2:rxandroid:2.1.1' implementation 'io.reactivex.rxjava2:rxjava:2.2.19'

ObservableTransformer 封装

/**
 * Created by: PeaceJay
 * Created date: 2020/12/15.
 * Description: 线程调度封装
 */
@SuppressWarnings("unused")
public class Scheduler<T> implements ObservableTransformer<T, T> {

    @NotNull
    @Override
    public ObservableSource<T> apply(Observable<T> upstream) {
        return upstream
                .subscribeOn(Schedulers.io())
                .unsubscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread());
    }

    /**
     * 应用线程调度并绑定生命周期管理
     *
     * @param <T> 泛型
     * @return 返回转换操作
     */
    public static <T> ObservableTransformer<T, T> apply() {
        return new Scheduler<>();
    }
}

compose正式使用

rxjava io线程安全 rxjava 线程池_自定义_02

测试用例

Disposable disposable = Observable.just(1, 2, 3)
                .compose(Scheduler.apply())
                .subscribe(integer -> {
                    Log.i("TAG", String.valueOf(integer));
                });

输出:1,2,3