线程控制----Scheduler(调度器)
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 主线程运行。
我上一篇将了订阅,里面详细说了subscrib过程,然后还有rxJava基础篇之二里面也讲到了线程
切换,但是我那是从别的播客里面看到的并且是强行理解的。所以为认为.subscribeOn是制定那一
行代码前面锁发生的操作是在指定线程中。但是其实不是这样理解的。真正的原理是那句代码
指定subscribe()发生在指定的线程中,我前面一篇讲订阅的时候说了。那些onNext什么之类的
操作其实都是在subscibe的内部被调用的,所以两者概念看起来结果是一样,但是本质理解是有
很大区别的。而.observerOn是指定Subscriber也就是Observer的回调线程。
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 主线程运行。
我上一篇将了订阅,里面详细说了subscrib过程,然后还有rxJava基础篇之二里面也讲到了线程
切换,但是我那是从别的播客里面看到的并且是强行理解的。所以为认为.subscribeOn是制定那一
行代码前面锁发生的操作是在指定线程中。但是其实不是这样理解的。真正的原理是那句代码
指定subscribe()发生在指定的线程中,我前面一篇讲订阅的时候说了。那些onNext什么之类的
操作其实都是在subscibe的内部被调用的,所以两者概念看起来结果是一样,但是本质理解是有
很大区别的。而.observerOn是指定Subscriber也就是Observer的回调线程。