Rxjava浅理解

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 主线程运行。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值