Rxjava(线程类)--observeOn和subscribeOn实例

observeOn作用于该操作符之后操作符直到出现新的observeOn操作符

        System.out.println("<<<<<< main threadid = " + Thread.currentThread().getId());
        Observable.just(1).map(new Func1<Integer, Integer>() {
            @Override
            public Integer call(Integer integer) {
                System.out.println("<<<<<< thread id = " + Thread.currentThread().getId());
                return integer * 2;
            }
        }).observeOn(Schedulers.from(JobExecutor.getInstance())).flatMap(new Func1<Integer, Observable<Integer>>() {
            @Override
            public Observable<Integer> call(Integer integer) {
                System.out.println("<<<<<< thread id = " + Thread.currentThread().getId());
                return Observable.just(integer);
            }
        }).observeOn(Schedulers.from(JobExecutor.getInstance())).subscribe(new Action1<Integer>() {
            @Override
            public void call(Integer integer) {
                System.out.println("<<<<<< thread id = " + Thread.currentThread().getId());
                System.out.print(integer + ", ");
            }
        });

结果:

<<<<<< main threadid = 1
<<<<<< thread id = 1
<<<<<< thread id = 15
<<<<<< thread id = 13
第一个map之后我们没改变线程,使用的是前面一样的进程,而后面我们利用 observeOn改变了线程,打印的id也不一样


subscribeOn 作用于该操作符之前的 Observable 的创建操符作以及 doOnSubscribe 操作符 ,换句话说就是 doOnSubscribe 以及 Observable 的创建操作符总是被其之后最近的 subscribeOn 控制。

我们看几个例子就明白了

 System.out.println("<<<<<< main threadid = " + Thread.currentThread().getId());
        Observable.just(1).map(new Func1<Integer, Integer>() {
            @Override
            public Integer call(Integer integer) {
                System.out.println("<<<<<<map thread id = " + Thread.currentThread().getId());
                return integer * 2;
            }
        }).doOnSubscribe(new Action0() {
            @Override
            public void call() {
                System.out.println("<<<<<<doOnSubscribe thread id = " + Thread.currentThread().getId());
            }
        }).subscribeOn(Schedulers.from(JobExecutor.getInstance())).observeOn(Schedulers.from(JobExecutor.getInstance())).flatMap(new Func1<Integer,
                Observable<Integer>>
                () {
            @Override
            public Observable<Integer> call(Integer integer) {
                System.out.println("<<<<<<flatMap thread id = " + Thread.currentThread().getId());
                return Observable.just(integer);
            }
        }).observeOn(Schedulers.from(JobExecutor.getInstance())).subscribe(new Action1<Integer>() {
            @Override
            public void call(Integer integer) {
                System.out.println("<<<<<<subscribe thread id = " + Thread.currentThread().getId());
                System.out.print(integer + ", ");
            }
        });
输出;

<<<<<< main threadid = 1
<<<<<<doOnSubscribe thread id = 15
<<<<<<map thread id = 15
<<<<<<flatMap thread id = 13
<<<<<<subscribe thread id = 14

doOnSubscribe() 执行在 subscribe() 发生的线程, 会在 subscribe 刚开始,而事件还未发送之前被调用,可以用于做一些准备工作。这里我们可以看到doOnSubscribe后面有一个subscribeOn,doOnSubscribe执行的线程也会被其影响,我们再看一下在之前的情况。

 System.out.println("<<<<<< main threadid = " + Thread.currentThread().getId());
        Observable.just(1).map(new Func1<Integer, Integer>() {
            @Override
            public Integer call(Integer integer) {
                System.out.println("<<<<<<map thread id = " + Thread.currentThread().getId());
                return integer * 2;
            }
        }).subscribeOn(Schedulers.from(JobExecutor.getInstance())).doOnSubscribe(new Action0() {
            @Override
            public void call() {
                System.out.println("<<<<<<doOnSubscribe thread id = " + Thread.currentThread().getId());
            }
        }).observeOn(Schedulers.from(JobExecutor.getInstance())).flatMap(new Func1<Integer,
                Observable<Integer>>
                () {
            @Override
            public Observable<Integer> call(Integer integer) {
                System.out.println("<<<<<<flatMap thread id = " + Thread.currentThread().getId());
                return Observable.just(integer);
            }
        }).observeOn(Schedulers.from(JobExecutor.getInstance())).subscribe(new Action1<Integer>() {
            @Override
            public void call(Integer integer) {
                System.out.println("<<<<<<subscribe thread id = " + Thread.currentThread().getId());
                System.out.print(integer + ", ");
            }
        });
<<<<<< main threadid = 1
<<<<<<doOnSubscribe thread id = 1
<<<<<<map thread id = 15
<<<<<<flatMap thread id = 14
<<<<<<subscribe thread id = 13

可以看到 doOnSubscribe执行线程没有收到影响,因为前面没有subscribeOn


再看一下有多个subscribeOn

      System.out.println("<<<<<< main threadid = " + Thread.currentThread().getId());
        Observable.just(1).map(new Func1<Integer, Integer>() {
            @Override
            public Integer call(Integer integer) {
                System.out.println("<<<<<<map thread id = " + Thread.currentThread().getId());
                return integer * 2;
            }
        }).doOnSubscribe(new Action0() {
            @Override
            public void call() {
                System.out.println("<<<<<<doOnSubscribe1 thread id = " + Thread.currentThread().getId());
            }
        }).subscribeOn(Schedulers.from(JobExecutor.getInstance())).doOnSubscribe(new Action0() {
            @Override
            public void call() {
                System.out.println("<<<<<<doOnSubscribe2 thread id = " + Thread.currentThread().getId());
            }
        }).subscribeOn(Schedulers.from(JobExecutor.getInstance())).observeOn(Schedulers.from(JobExecutor.getInstance
                ())).flatMap(new Func1<Integer,
                Observable<Integer>>
                () {
            @Override
            public Observable<Integer> call(Integer integer) {
                System.out.println("<<<<<<flatMap thread id = " + Thread.currentThread().getId());
                return Observable.just(integer);
            }
        }).observeOn(Schedulers.from(JobExecutor.getInstance())).subscribe(new Action1<Integer>() {
            @Override
            public void call(Integer integer) {
                System.out.println("<<<<<<subscribe thread id = " + Thread.currentThread().getId());
                System.out.print(integer + ", ");
            }
        });
<<<<<< main threadid = 1
<<<<<<doOnSubscribe2 thread id = 15
<<<<<<doOnSubscribe1 thread id = 13
<<<<<<map thread id = 14
<<<<<<flatMap thread id = 13
<<<<<<subscribe thread id = 15

可以看到, subscribeOn影响的是它之前的,而且多个也有效。

参考:

http://www.jianshu.com/p/59c3d6bb6a6b


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值