想把之前写的多线程下载文件的库用RxJava重新实现一下,于是看了看在RxJava如何实现并发。
首先说一点,RxJava里的subscribeOn以及observeOn这两个Operator仅能用来实现线程切换,其整个数据流及操作还是串行的,没有任何并发的意思。
实现办法也就是标题里面的那两个Operator:
flatMap()
flatMap操作符做了两件事:
- map:对每个来自upstream的事件作映射处理,生成一个数据流sub-Stream。因此此步骤结束后,存在的是一个数据流(即sub-Stream)的数据流。
- flat:对每个来自upstream(也就map这一步的结果)的事件(也就是sub-Stream)进行订阅,只要某个sub-Stream发射了事件就立即转发给下流。
然后这其中的flat这一步不用管,人家做的很好了。map这一步本身就是由用户自己定义的,可以通过subscribeOn操作符来控制生成sub-Stream的操作在哪些线程上执行,这样也就能够实现并发的效果。
Flowable.just(1