RxJava学习历程(二)

今天继续学习RxJava,新技能get了总要记录一下。
上篇文章写到的生成观察者的两种方式其实是有区别的,例如

先看下面的代码:

    private String name="lily";
private Observable<String> defObserveable;
private Observable<String> justObserveable;
private Observable<String> comObservable;

private Subscriber<String> subscriber;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    defObserveable = Observable.defer(new Func0<Observable<String>>() {
       @Override
       public Observable<String> call() {
           return Observable.just(name);
       }
   });
    justObserveable = Observable.just(name);
    comObservable=Observable.create(new Observable.OnSubscribe<String>() {
        @Override
        public void call(Subscriber<? super String> subscriber) {
            subscriber.onNext(name);
        }
    });
    subscriber = new Subscriber<String>() {
        @Override
        public void onCompleted() {

        }

        @Override
        public void onError(Throwable e) {

        }

        @Override
        public void onNext(String s) {
            PluLogUtil.log("---onNext name is " + s);
        }
    };
    name ="lucy";
    comObservable.subscribe(subscriber);
    defObserveable.subscribe(subscriber);
    justObserveable.subscribe(subscriber);
    //打印结果:
    //---_PLU LOG ---onNext name is lucy
    //---_PLU LOG ---onNext name is lucy
    // ---_PLU LOG ---onNext name is lily

}

可以看到just(param)方式与其他方式区别是参数是否变化。

just方式里面的参数不会随外部参数的变化而变化,但如果在其外层加了一层def的方式的话当外部参数变化的时候参数值也随一起变化,这点需要注意。而用create方式生成的Observable,要看subscribe方法的调用发生在name变量变化的前面还是后面,若在name变量值改变后调用的subscribe,因为Observer创建时OnSubscribe里面的call方法的调用是发生在subscribe调用的时候,所以name变化传入的值也会变化,如果subscribe之后再改变name的值那也不会随之变。

RxJava的运行所在线程总结:

先上代码:

 Observable.create(new Observable.OnSubscribe<Integer>() {
        @Override
        public void call(Subscriber<? super Integer> subscriber) {// IO 线程,由 subscribeOn() 指定
            subscriber.onNext(3);
            PluLogUtil.log(" --  onSubscribe call thread is "+Thread.currentThread().getName());

        }
    }).subscribeOn(Schedulers.io())
            .subscribeOn(Schedulers.newThread())
            .observeOn(Schedulers.io())
            .map(new Func1<Integer, Integer>() {
                @Override
                public Integer call(Integer integer) {// io线程,由 observeOn() 指定
                    PluLogUtil.log("---map 111 thread is " + Thread.currentThread().getName());
                    return integer + 1;
                }
            })
            .observeOn(Schedulers.newThread())
            .observeOn(Schedulers.io())
            .map(new Func1<Integer, Integer>() {
                @Override
                public Integer call(Integer integer) {//io线程,由 observeOn() 指定
                    PluLogUtil.log("----map 2 22 thread is " + Thread.currentThread().getName());
                    return integer + 1;
                }
            })
            .observeOn(Schedulers.newThread())
            .map(new Func1<Integer, Integer>() {
                @Override
                public Integer call(Integer integer) {// 新线程,由 observeOn() 指定
                    PluLogUtil.log("----map 333 thread is " + Thread.currentThread().getName());
                    return integer + 1;
                }
            })
            .doOnSubscribe(new Action0() {//io线程,由其后的第一个subscribeOn所限定的线程决定
                @Override
                public void call() {
                    PluLogUtil.log("----doOnSubscribe thread is "+Thread.currentThread().getName());
                }
            }).subscribeOn(Schedulers.io()).
            subscribe(new Subscriber<Integer>() {
                @Override
                public void onCompleted() {

                }

                @Override
                public void onError(Throwable e) {

                }

                @Override
                public void onNext(Integer integer) {//新线程,由最后一个observeOn的线程限定
                    PluLogUtil.log("---onNext thread is " + Thread.currentThread().getName());
                }
            });

    /**
     * 03-10 23:20:51.360 8134-8134/? D/TAG_PluginDeliverService: PluginDeliverService start com.sina.weibo.plugin.PluginDeliverService$PluginDeliverService3
     ---_PLU LOG ----doOnSubscribe thread is RxCachedThreadScheduler-1
     ---_PLU LOG  --  onSubscribe call thread is RxCachedThreadScheduler-4
     ---_PLU LOG ---map 111 thread is RxCachedThreadScheduler-3
     ---_PLU LOG ----map 2 22 thread is RxCachedThreadScheduler-2
     ---_PLU LOG ----map 333 thread is RxNewThreadScheduler-1
     ---_PLU LOG ---onNext thread is RxNewThreadScheduler-1

     */

说下我自己的理解:

1.subscribeOn限定被观察者运行的线程

2.observeOn限定观察者运行的线程

3.map指令:

1>如果map前面没有observeOn&&没有subscribeOn,则该map所在的线程为主线程。

2>如果map前面只有subscribeOn则运行在scribeOn指定的线程。

3>如果map前面有observeOn(不管subscribeOn有没有)则map里代码运行在其前面的最后一个onserveOn所限定的线程上。

4.doOnSubscribe里面运行的代码所在的线程取决于其后面的第一个subscribeOn里面指定的线程的名字,请注意第一字眼和其后面的字眼。

5.subscribe的onNext:若指定了多个observeOn,则subscribe的onNext里面运行的代码使用的线程是最后一个subscribeOn限定的线程。

呼啦啦,写的跨度可能比较大,明天再继续分析,如有不对欢迎批评指正。睡啦,呼呼~~~

你可能感兴趣的:(rxjava)