一、map
Map
操作符对原始Observable发射的每一项数据应用一个你选择的函数,然后返回一个发射这些结果的Observable。
private void testMap() {
String[]items = {"just1","just2","just3","just4","just5","just6"};
Observable<String> myObservable = Observable.from(items)
.map(new Func1<String, String>() {
@Override
public String call(String s) {
return mapInfo(s);
}
});
Subscriber<String> mySubscriber = new Subscriber<String>() {
@Override
public void onNext(String s) {
System.out.println("onNext................."+s);
}
@Override
public void onCompleted() {
System.out.println("onCompleted.................");
}
@Override
public void onError(Throwable e) {
System.out.println("onError....................");
}
};
myObservable.subscribe(mySubscriber);
}
private String mapInfo(String s){
return s+" had mapped;";
}
运行结果:
二、cast
cast
操作符将原始Observable发射的每一项数据都强制转换为一个指定的类型,然后再发射数据,它是map
的一个特殊版本
注:所相互转换的类之间需要存在某种关系,如继承、实现
List<Machine> items = new ArrayList<>();
for (int i=0;i<3;i++){
items.add(new Computer("computer"+i,"material"+i));
}
Observable<Computer> myObservable =
Observable.from(items)
.cast(Computer.class);
// .cast(TestCastEntity.class);
Subscriber<Computer> mySubscriber = new Subscriber<Computer>() {
@Override
public void onNext(Computer s) {
System.out.println("onNext................."+s.name+".........."+s.material);
}
@Override
public void onCompleted() {
System.out.println("onCompleted.................");
}
@Override
public void onError(Throwable e) {
System.out.println("onError....................");
}
};
myObservable.subscribe(mySubscriber);
}
public class Machine {
public String name;
public Machine(String name){
this.name = name;
}
}
public class Computer extends Machine{
public String material;
public Computer(String name,String material){
super(name);
this.material = material;
}
}
运行结果:
三、encode
encode
将一个发射字符串的Observable变换为一个发射字节数组(这个字节数组按照原始字符串中的多字节字符边界划分)的Observable。
四、byLine
byLine
将一个发射字符串的Observable变换为一个按行发射来自原始Observable的字符串的Observable。
五、flatmap
FlatMap
操作符使用一个指定的函数对原始Observable发射的每一项数据执行变换操作,这个函数返回一个本身也发射数据的Observable,然后FlatMap
合并这些Observables发射的数据,最后将合并后的结果当做它自己的数据序列发射。
flatmap通过一个函数将原来的数据的每一项进行转换,并将返回的数据进行Observable包装,然后将所有这些Observable转换成一个Observable发射,所执行的结果可能和元数据items中数据的顺序不一致
private void testFlatMap() {
Integer[]items = {1,2,3,4,5,6};
Observable<String> myObservable = Observable.from(items)
.flatMap(new Func1<Integer, Observable<String>>() {
@Override
public Observable<String> call(Integer i) {
return Observable.just(flatMapInfo(i));
}
});
Subscriber<String> mySubscriber = new Subscriber<String>() {
@Override
public void onNext(String s) {
System.out.println("onNext................."+s);
}
@Override
public void onCompleted() {
System.out.println("onCompleted.................");
}
@Override
public void onError(Throwable e) {
System.out.println("onError....................");
}
};
myObservable.subscribe(mySubscriber);
}
private String flatMapInfo(Integer i){
return "flatmap" + i;
}
运行结果:
六、flatmapiteriable
使用iterable作为源数据再将其转换成多个observable
Integer[]items = {1,2,3,4,5,6};
Observable<String> myObservable = Observable.from(items)
.flatMapIterable(new Func1<Integer, Iterable<? extends String>>() {
@Override
public Iterable<String> call(Integer integer) {
ArrayList<String> strings = new ArrayList<String>();
strings.add("iterable"+integer);
return strings;
}
});
Subscriber<String> mySubscriber = new Subscriber<String>() {
@Override
public void onNext(String s) {
System.out.println("onNext................."+s);
}
@Override
public void onCompleted() {
System.out.println("onCompleted.................");
}
@Override
public void onError(Throwable e) {
System.out.println("onError....................");
}
};
myObservable.subscribe(mySubscriber);
运行结果:
七、concatMap
concatMap
操作符,它类似于最简单版本的flatMap
,但是它按次序连接而不是合并那些生成的Observables,然后产生自己的数据序列。
switchMap
操作符。它和flatMap
很像,除了一点:当原始Observable发射一个新的数据(Observable)时,它将取消订阅并停止监视产生执之前那个数据的Observable,只监视当前这一个。
Integer[]items = {1,2,3,4,5,6};
Observable<String> myObservable = Observable.from(items)
.switchMap(new Func1<Integer, Observable<String>>() {
@Override
public Observable<String> call(Integer integer) {
return Observable.just(integer+"").subscribeOn(Schedulers.newThread());
}
});
Subscriber<String> mySubscriber = new Subscriber<String>() {
@Override
public void onNext(String s) {
System.out.println("onNext................."+s);
}
@Override
public void onCompleted() {
System.out.println("onCompleted.................");
}
@Override
public void onError(Throwable e) {
System.out.println("onError....................");
}
};
myObservable.subscribe(mySubscriber);
运行结果:
split
操作符将一个发射字符串的Observable转换为另一个发射字符串的Observable,只不过,后者将原始的数据序列当做一个数据流,使用一个正则表达式边界分割它们,然后合并发射分割的结果。