连续地对数据序列的每一项应用一个函数,然后连续发射结果
我们看一个demo
Observable.range(1, 10).scan(new Func2<Integer, Integer, Integer>() {
@Override
public Integer call(Integer integer, Integer integer2) {
return integer + integer2;
}
}).subscribe(new Action1<Integer>() {
@Override
public void call(Integer integer) {
System.out.println(integer + "");
}
});
1
3
6
10
15
21
28
36
45
55
这里首先1 第二项是前面输出的1再加上2,第三项是前面的1+2再加上3.....
我们看下scan的实现
public final Observable<T> scan(Func2<T, T, T> accumulator) {
return lift(new OperatorScan<T, T>(accumulator));
}
创建了一个OperatorScan
public OperatorScan(final Func2<R, ? super T, R> accumulator) {
this((R) NO_INITIAL_VALUE, accumulator);
}
这里主要分析一下OperatorScan的call
public Subscriber<? super T> call(final Subscriber<? super R> child) {
final R initialValue = initialValueFactory.call();
if (initialValue == NO_INITIAL_VALUE) {
return new Subscriber<T>(child) {
boolean once;
R value;
@SuppressWarnings("unchecked")
@Override
public void onNext(T t) {
R v;
if (!once) {
once = true;
v = (R)t;
} else {
v = value;
try {
v = accumulator.call(v, t);
} catch (Throwable e) {
Exceptions.throwOrReport(e, child, t);
return;
}
}
value = v;
child.onNext(v);
}
@Override
public void onError(Throwable e) {
child.onError(e);
}
@Override
public void onCompleted() {
child.onCompleted();
}
};
}
once第一次进来为false,走if分支,once设置为true,把值v保存到value,下次再进来时,once为true,走else分支
调用accumulator对前面保存的value和刚传进来的t值进行操作,最后调用onNext