添加依赖
- compile ‘io.reactivex:rxjava:1.1.6’
- compile ‘io.reactivex:rxandroid:1.2.1’
Lambda表达式:
step1.在根目录下的build.gradle添加:dependencies { ... classpath 'me.tatarka:gradle-retrolambda:3.2.5' ... }
step2.在app下的build.gradle添加:
apply plugin: ‘me.tatarka.retrolambda’android { ... compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } ...
}
基本用法
- 创建被观察者Observable,oncreate或just依次调用参数
- 创建观察者Subscriber/observer,其中onCompleted、onError和onNext是必须要实现的方法
- 订阅 observable.subsribe(observer)
- RxJava源码提供了一堆Action
RxJava 已经内置了5个 Scheduler用于切换线程
btnStart.setEnabled(false);
Observable.create(new Observable.OnSubscribe() {
@Override
public void call(Subscriber
关于Subject的使用
注意
- 在RxJava中,Observable可以被分为Hot bservable
与Cold Observable
- 把Hot Observable比喻成一个电台,听众从某个时刻收听这个电台开始就可以听到此时播放的节目以及之后的节目,但是无法听到电台此前播放的节目
- 而Cold Observable就像音乐 CD ,人们购买 CD 的时间可能前后有差距,但是收听 CD 时都是从第一个曲目开始播放的。也就是说同一张 CD ,每个人收听到的内容都是一样的, 无论收听时间早或晚。
- Subject 属于Cold Observable
- 一定要用Subcect.create()的方式创建并使用,不要用just(T)、from(T)、create(T)创建,否则会导致失效…
分类
- AsyncSubject
- 用AsyncSubject无论输入多少参数,永远只输出最后一个参数。
- BehaviorSubject
- 发送离订阅最近的上一个值,没有上一个值的时候会发送默认值,如果遇到错误会直接中断
- PublishSubject
- 最正常的Subject,从那里订阅就从那里开始发送数据。
- ReplaySubject
- 无论何时订阅,都会将所有历史订阅内容全部发出。