标签:
你可以使用Create
操作符从头开始创建一个Observable
,给这个操作符传递一个接受观察者作为参数的函数,编写这个函数让它的行为表现为一个Observable
–恰当的调用观察者的onNext
,onError
和onCompleted
方法。
一个形式正确的有限Observable
必须尝试调用观察者的onCompleted
正好一次或者它的onError正好一次,而且此后不能再调用观察者的任何其它方法。
RxJava
将这个操作符实现为create
方法。
建议你在传递给create
方法的函数中检查观察者的isUnsubscribed
状态,以便在没有观察者的时候,让你的Observable
停止发射数据或者做昂贵的运算。
示例代码:
Observable.create(new Observable.OnSubscribe<Integer>() {
@Override
public void call(Subscriber<? super Integer> observer) {
try {
if (!observer.isUnsubscribed()) {
for (int i = 1; i < 5; i++) {
observer.onNext(i);
}
observer.onCompleted();
}
} catch (Exception e) {
observer.onError(e);
}
}
} ).subscribe(new Subscriber<Integer>() {
@Override
public void onNext(Integer item) {
System.out.println("Next: " + item);
}
@Override
public void onError(Throwable error) {
System.err.println("Error: " + error.getMessage());
}
@Override
public void onCompleted() {
System.out.println("Sequence complete.");
}
});
输出:
Next: 1
Next: 2
Next: 3
Next: 4
Sequence complete.
create
方法默认不在任何特定的调度器上执行。
* Javadoc:create(OnSubscribe)
*
创建一个发射指定值的Observable
Just
将单个数据转换为发射那个数据的Observable
。
Just
类似于From
,但是From
会将数组或Iterable
的数据取出然后逐个发射,而Just
只是简单的原样发射,将数组或Iterable
当做单个数据。
注意:如果你传递null
给Just
,它会返回一个发射null
值的Observable
。不要误认为它会返回一个空Observable
(完全不发射任何数据的Observable
),如果需要空Observable
你应该使用Empty
操作符。
RxJava
将这个操作符实现为just
函数,它接受一至九个参数,返回一个按参数列表顺序发射这些数据的Observable
。
示例代码:
Observable.just(1, 2, 3)
.subscribe(new Subscriber<Integer>() {
@Override
public void onNext(Integer item) {
System.out.println("Next: " + item);
}
@Override
public void onError(Throwable error) {
System.err.println("Error: " + error.getMessage());
}
@Override
public void onCompleted() {
System.out.println("Sequence complete.");
}
});
输出
Next: 1
Next: 2
Next: 3
Sequence complete.
将其它种类的对象和数据类型转换为Observable
当你使用Observable
时,如果你要处理的数据都可以转换成展现为Observables
,而不是需要混合使用Observables
和其它类型的数据,会非常方便。这让你在数据流的整个生命周期中,可以使用一组统一的操作符来管理它们。
例如,Iterable
可以看成是同步的Observable
;Future
,可以看成是总是只发射单个数据的Observable
。通过显式地将那些数据转换为Observables
,你可以像使用Observable
一样与它们交互。
因此,大部分ReactiveX
实现都提供了将语言特定的对象和数据结构转换为Observables
的方法。
在RxJava
中,from
操作符可以转换Future
、Iterable
和数组。对于Iterable
和数组,产生的Observable
会发射Iterable
或数组的每一项数据。
示例代码
Integer[] items = { 0, 1, 2, 3, 4, 5 };
Observable myObservable = Observable.from(items);
myObservable.subscribe(
new Action1<Integer>() {
@Override
public void call(Integer item) {
System.out.println(item);
}
},
new Action1<Throwable>() {
@Override
public void call(Throwable error) {
System.out.println("Error encountered: " + error.getMessage());
}
},
new Action0() {
@Override
public void call() {
System.out.println("Sequence complete");
}
}
);
输出
0
1
2
3
4
5
Sequence complete
对于Future
,它会发射Future.get()
方法返回的单个数据。from
方法有一个可接受两个可选参数的版本,分别指定超时时长和时间单位。如果过了指定的时长Future
还没有返回一个值,这个Observable
会发射错误通知并终止。
from
默认不在任何特定的调度器上执行。然而你可以将Scheduler
作为可选的第二个参数传递给Observable
,它会在那个调度器上管理这个Future
。
直到有观察者订阅时才创建Observable
,并且为每个观察者创建一个新的Observable
Defer
操作符会一直等待直到有观察者订阅它,然后它使用Observable
工厂方法生成一个Observable
。它对每个观察者都这样做,因此尽管每个订阅者都以为自己订阅的是同一个Observable
,事实上每个订阅者获取的是它们自己的单独的数据序列。
在某些情况下,等待直到最后一分钟(就是知道订阅发生时)才生成Observable
可以确保Observable
包含最新的数据。
示例代码
str = "你是不是傻";
Observable<String> just_Observable = Observable.just(str);
str = "你猜";
Observable<String> defer_Observable = Observable.defer(new Func0<Observable<String>>() {
@Override
public Observable<String> call() {
return Observable.just(str);
}
});
str = "哈哈";
just_Observable.subscribe(new Action1<String>() {
@Override
public void call(String s) {
Log.i("sss",s);
}
});
defer_Observable.subscribe(new Action1<String>() {
@Override
public void call(String s) {
Log.i("sss",s);
}
});
输出
07-04 15:04:40.582 1699-1699/? I/sss: 你是不是傻
07-04 15:04:40.582 1699-1699/? I/sss: 哈哈
RxJava
将这个操作符实现为 defer
方法。这个操作符接受一个你选择的Observable
工厂函数作为单个参数。这个函数没有参数,返回一个Observable
。
defer
方法默认不在任何特定的调度器上执行。
* Javadoc: defer(Func0)
Observable
,它在一个给定的延迟后发射一个特殊的值。
Timer
操作符创建一个在给定的时间段之后返回一个特殊值的Observable
。
RxJava
将这个操作符实现为timer
函数。
timer
返回一个Observable
,它在延迟一段给定的时间后发射一个简单的数字0
。
timer
操作符默认在computation
调度器上执行。有一个变体可以通过可选参数指定Scheduler
。
示例代码
Observable.timer(3,TimeUnit.SECONDS)
.subscribe(new Observer<Long>() {
@Override
public void onCompleted() {
}
@Override
public void onError(Throwable e) {
}
@Override
public void onNext(Long number) {
Log.d("RXJAVA", "I say " + number);
}
});
输出
它将`3`秒后发射`0`,然后就完成了
但是这个已经不建议使用了,废弃掉了,因为一个名叫interval的操作符有同样的功能。
)
示例代码
Observable.timer(3,3,TimeUnit.SECONDS)
.subscribe(new Observer<Long>() {
@Override
public void onCompleted() {
}
@Override
public void onError(Throwable e) {
}
@Override
public void onNext(Long number) {
Log.d("RXJAVA", "I say " + number);
}
});
输出
每隔`3`秒产生一个数字
I say 0
I say 1
I say 2
I say 3
...
Interval
操作符返回一个Observable
,它按固定的时间间隔发射一个无限递增的整数序列。
它接受一个表示时间间隔的参数和一个表示时间单位的参数
range
操作符是创建一组在从n
开始,个数为m
的连续数字,比如range(3,10)
,就是创建3、4、5…12
的一组数字
示例代码
Observable.range(3,10).subscribe(new Subscriber<Integer>() {
@Override
public void onCompleted() {
System.out.println("Sequence complete.");
}
@Override
public void onError(Throwable e) {
System.out.println("error:" + e.getMessage());
}
@Override
public void onNext(Integer i) {
System.out.println("Next:" + i.toString());
}
});
输出
Next:3
Next:4
Next:5
Next:6
...
Next:12
Sequence complete.
range
默认不在任何特定的调度器上执行。有一个变体可以通过可选参数指定Scheduler
。
Repeat重复地发射数据。某些实现允许你重复的发射某个数据序列,还有一些允许你限制重复的次数。
RxJava
将这个操作符实现为repeat
方法。它不是创建一个Observable
,而是重复发射原始Observable
的数据序列,这个序列或者是无限的,或者通过repeat(n)
指定重复次数。
repeat
操作符默认在trampoline
调度器上执行。有一个变体可以通过可选参数指定Scheduler
。
示例代码
Observable.range(3,2).repeat(3).subscribe(new Action1<Integer>() {
@Override
public void call(Integer integer) {
Log.i("sss",integer+" ");
}
});
输出
I/sss: 3
I/sss: 4
I/sss: 3
I/sss: 4
I/sss: 3
I/sss: 4
将原始Observable
的终止通知(完成或错误)当做一个void
数据传递给一个通知处理器,它以此来决定是否要重新订阅和发射原来的Observable
。这个通知处理器就像一个Observable
操作符,接受一个发射void
通知的Observable
为输入,返回一个发射void
数据(意思是,重新订阅和发射原始Observable
)或者直接终止(意思是,使用repeatWhen
终止发射数据)的Observable
。
示例代码
Observable.just(1,2,3,4).repeatWhen(new Func1<Observable<? extends Void>, Observable<?>>() {
@Override
public Observable<?> call(Observable<? extends Void> observable) {
// 延迟1秒
return Observable.timer(1,TimeUnit.SECONDS);
}
}).subscribe(new Action1<Integer>() {
@Override
public void call(Integer integer) {
System.out.println(""+integer);
}
});
输出
I/System.out: 1
I/System.out: 2
I/System.out: 3
I/System.out: 4
I/System.out: 1
I/System.out: 2
I/System.out: 3
I/System.out: 4
repeatWhen
操作符默认在trampoline
调度器上执行。有一个变体可以通过可选参数指定Scheduler
。
参考:
http://rxjava.yuxingxin.com/chapter5/the_map_family.html
https://github.com/mcxiaoke/RxDocs
https://www.gitbook.com/book/mcxiaoke/rxdocs
RxJava 学习笔记(五) --- Creating 创建操作符
标签:
原文地址:http://blog.csdn.net/urrjdg/article/details/51832478