[RxJava] 并发之flatMap() VS parallel()

本文探讨了如何使用RxJava实现并发,指出subscribeOn和observeOn无法实现并发,而flatMap和parallel操作符可以实现这一目标。flatMap通过映射和订阅实现并发,用户可以控制在哪个线程上执行。parallel在RxJava 2.0.5中引入,提供更简洁的并发处理,将Flowable转换为ParallelFlowable,并在其内部并行运行操作。
摘要由CSDN通过智能技术生成

想把之前写的多线程下载文件的库用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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值