Rxjava浅理解

来源:互联网 发布:浩方对战平台mac版 编辑:程序博客网 时间:2024/06/08 15:02

RxJava其实就是一个词异步,它是一个扩展的观察者模式,下面简单介绍一下初步使用方法:

被观察者Observable: 被观察者将数据发射出去

  • 其创建方法可以使用.just()和.from()进行创建,其中.just(“1”,”“2”,”3”,”4”,”5”)会将参数依次发射出去,.form()会将传入的数组或者 Iterable 拆分成具体对象后,依次发送出来:String[] words = {“Hello”, “Nihao”, “hwb”};
    Observable observable = Observable.from(words);

Observable observable0 = Observable.create(new Observable.OnSubscribe()
{
@Override
public void call (Subscriber< ? super String> subscriber)
{
subscriber.onNext(“aaa”);
subscriber.onCompleted();
}
});

观察者Observer:接收发射的数据

Observer observer = new Observer() {
@Override
public void onCompleted() {
Logger.d(“zx Observer onCompleted”);
}

        @Override        public void onError(Throwable e) {            Logger.d("zx Observer onError");        }        @Override        public void onNext(Integer integer) {            Logger.d("zx Observer onNext :" + integer);        }    };

Action1()以及Action0()函数可以当做一个包装对象,将onNext()/onError()/onCompleted()的内容打包起来传入subscribe中以实现不完整定义的回调

订阅Subscribe,当订阅完成之后,被观察者开始发射数据

Observable.subscribe(observer);

线程控制

.subscribeOn(Schedulers.io())订阅发现在io线程
.obseveOn(AndroidSchedulers.mainThread())回调执行在主线程
- 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 主线程运行。