RxJava 中的 'Subscriber Thread' 是什么意思
What Is Meant By 'Subscriber Thread' in RxJava
我在读一本关于 RxJava 的书,下面是其中的摘录:
Observable.create(s -> {
... async subscription and data emission ...
})
.doOnNext(i -> System.out.println(Thread.currentThread()))
.filter(i -> i % 2 == 0)
.map(i -> "Value " + i + " processed on " + Thread.currentThread())
.subscribe(s -> System.out.println("SOME VALUE =>" + s));
System.out.println("Will print BEFORE values are emitted")”
他写道,由于操作是异步的,值将在不同于订阅者线程的线程上发出。由于订阅者的线程是非阻塞的,因此 Will print BEFORE values are emitted
将在任何值被推送到订阅者之前打印出来。
我无法理解这个订阅者线程是什么?我能以某种方式得到它的名字吗?为了测试作者在说什么,我写了一些代码:
Observable.create(
subscriber -> {
System.out.println("Entering thread: " + Thread.currentThread().getName());
Thread t =
new Thread(
new Runnable() {
@Override
public void run() {
try {
System.out.println(
"Emitting threads: " + Thread.currentThread().getName());
Thread.sleep(5000);
subscriber.onNext(1);
subscriber.onNext(2);
subscriber.onNext(3);
subscriber.onCompleted();
} catch (InterruptedException e) {
subscriber.onError(e);
}
}
});
t.start();
})
.subscribe(
a -> {
System.out.print("Subscriber thread: " + Thread.currentThread().getName() + " ");
System.out.println(a);
});
System.out.println("Main thread exiting:");
当我 运行 上述代码时,我发现订阅者线程与调用 onNext()
的线程相同。由于这是一个异步操作,因此项目应该在与订阅者线程不同的线程上发出。怎么两个线程都一样?
此外,即使在主线程退出后,程序仍保持 运行ning 并仅在通过 onNext() 将所有元素下推后才终止。为什么会这样?为什么程序没有退出?
默认情况下,Rx 是单线程的,这意味着 Observable
和我们可以应用于它的运算符链将在其 subscribe()
方法所在的同一线程上通知其观察者被调用。
订阅者线程是调用 subscribe
的线程。由于 RxJava 流是这样的订阅调用链,这些调用可以通过 subscribeOn
.
移动到序列中的其他线程。
例如:
Observable.fromCallable(() -> Thread.currentThread())
.subscribe(System.out::println);
System.out.println("Subscriber thread: " + Thread.currentThread());
这将打印订阅者线程两次。或者
Observable.fromCallable(() -> Thread.currentThread())
.subscribeOn(Schedulers.single())
.subscribe(System.out::println);
System.out.println("Subscriber thread: " + Thread.currentThread());
Thread.sleep(1000);
这将打印订阅者线程和 RxSingleScheduler 线程。
我在读一本关于 RxJava 的书,下面是其中的摘录:
Observable.create(s -> {
... async subscription and data emission ...
})
.doOnNext(i -> System.out.println(Thread.currentThread()))
.filter(i -> i % 2 == 0)
.map(i -> "Value " + i + " processed on " + Thread.currentThread())
.subscribe(s -> System.out.println("SOME VALUE =>" + s));
System.out.println("Will print BEFORE values are emitted")”
他写道,由于操作是异步的,值将在不同于订阅者线程的线程上发出。由于订阅者的线程是非阻塞的,因此 Will print BEFORE values are emitted
将在任何值被推送到订阅者之前打印出来。
我无法理解这个订阅者线程是什么?我能以某种方式得到它的名字吗?为了测试作者在说什么,我写了一些代码:
Observable.create(
subscriber -> {
System.out.println("Entering thread: " + Thread.currentThread().getName());
Thread t =
new Thread(
new Runnable() {
@Override
public void run() {
try {
System.out.println(
"Emitting threads: " + Thread.currentThread().getName());
Thread.sleep(5000);
subscriber.onNext(1);
subscriber.onNext(2);
subscriber.onNext(3);
subscriber.onCompleted();
} catch (InterruptedException e) {
subscriber.onError(e);
}
}
});
t.start();
})
.subscribe(
a -> {
System.out.print("Subscriber thread: " + Thread.currentThread().getName() + " ");
System.out.println(a);
});
System.out.println("Main thread exiting:");
当我 运行 上述代码时,我发现订阅者线程与调用 onNext()
的线程相同。由于这是一个异步操作,因此项目应该在与订阅者线程不同的线程上发出。怎么两个线程都一样?
此外,即使在主线程退出后,程序仍保持 运行ning 并仅在通过 onNext() 将所有元素下推后才终止。为什么会这样?为什么程序没有退出?
默认情况下,Rx 是单线程的,这意味着 Observable
和我们可以应用于它的运算符链将在其 subscribe()
方法所在的同一线程上通知其观察者被调用。
订阅者线程是调用 subscribe
的线程。由于 RxJava 流是这样的订阅调用链,这些调用可以通过 subscribeOn
.
例如:
Observable.fromCallable(() -> Thread.currentThread())
.subscribe(System.out::println);
System.out.println("Subscriber thread: " + Thread.currentThread());
这将打印订阅者线程两次。或者
Observable.fromCallable(() -> Thread.currentThread())
.subscribeOn(Schedulers.single())
.subscribe(System.out::println);
System.out.println("Subscriber thread: " + Thread.currentThread());
Thread.sleep(1000);
这将打印订阅者线程和 RxSingleScheduler 线程。