Java subscribe(consumer、errorConsumer、CompleteCumer、subscriptionConsumer)不调用consumer和CompleteCumer?
作为主题,Java subscribe(consumer、errorConsumer、CompleteCumer、subscriptionConsumer)不调用consumer和CompleteCumer?,java,project-reactor,Java,Project Reactor,作为主题,Mono.subscribe的第四个变体似乎没有调用成功消费者和完整消费者。它只调用订阅使用者 下面的代码失败 CountDownLatch latch = new CountDownLatch(3); Mono.just(1).subscribe(i -> latch.countDown(), throwable -> {}, latch::countDown, s -> latch.countDown()); boolean success
Mono.subscribe
的第四个变体似乎没有调用成功消费者和完整消费者。它只调用订阅使用者
下面的代码失败
CountDownLatch latch = new CountDownLatch(3);
Mono.just(1).subscribe(i -> latch.countDown(), throwable -> {}, latch::countDown, s -> latch.countDown());
boolean success = latch.await(1, TimeUnit.SECONDS);
Assert.assertEquals(true, success);
这是因为带有
消费者的订阅
版本旨在让您驱动初始请求
。如果您没有在消费者中对订阅调用request(n)
,则不会发出任何数据,Mono
将无法完成
这与预期的效果一样:
CountDownLatch latch = new CountDownLatch(3);
Mono.just(1).subscribe(
i -> latch.countDown(),
throwable -> {},
latch::countDown,
s -> {
s.request(Long.MAX_VALUE);
latch.countDown();
});
boolean success = latch.await(1, TimeUnit.SECONDS);
Assert.assertEquals(true, success);
谢谢@SimonBaslé,但是方法名表明它正在订阅。因此,用户必须使用传递到那里的订阅手动请求,这有点误导。在javadoc上没有给出任何线索。我同意,这应该更清楚。参数的描述中提到了这一点:“@param subscriptionConsumer要在订阅信号时调用的使用者,用于初始{@link Subscription#request(long)request},或null用于max request”