Convert a callback into a reactive publisher (Flux)(将回调转换为被动发布者(Flux))
本文介绍了将回调转换为被动发布者(Flux)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在使用第三方库注册MessageListener,当某些事件发生时,它们调用已注册的监听器onMessage方法
public interface MessageListener {
// third party code, it auto-scans for all MessageListeners and registers them
void onMessage(Message message);
}
public class SimpleMessageListener implements MessageListener {
public void onMessage(Message message) {
//do something non blocking
//is it possible to 'transmit' to messagePublisher
}
public Flux<Message> messagePublisher() {
// a method to which to subscribeOn
}
}
所以我的问题是,将其转化为流量的最佳方法是什么
最后,我希望能够做这样的事情
messagePublisher().subscribe(System.out::println);
编辑*
我的第一次尝试是这样的
private List<FluxSink<Message>> handlers = new ArrayList<>();
public void onMessage(Message message) {
handlers.forEach(han -> han.next(message));
}
public Flux<Message> messagePublisher() {
return Flux.create(sink -> {
handlers.add(sink);
sink.onDispose(() -> handlers.remove(sink));
});
}
有效-但我觉得这不是一个很好的解决方案,让类实现FlosSink并手动处理是不是更好--目前我预计不会有很多订阅者。 但是有许多MessageListeners(每种类型一个)
推荐答案
您可以创建单个Flux
实例来桥接MessageListener
观察到的消息,例如
public class SimpleMessageListener implements MessageListener {
private FluxSink<Message> handler;
private Flux<Message> flux;
public SimpleMessageListener() {
flux = Flux.create(emitter -> {
handler = emitter;
}, OverflowStrategy.DROP); // or some other overflow strategy
}
public void onMessage(Message message) {
if (handler != null) {
/*
* null check is required to avoid NPE if a message is received
* before any subscription occurs since handler is instantiated
* lazily when the first subscription is requested
*/
handler.next(message);
}
}
public Flux<Message> messagePublisher() {
return flux;
}
}
现在所有监听器都可以使用Flux‘publish()方法及其返回的ConnectableFlux订阅相同的messsagePublisher()
Flux
实例:
// fetch message publisher
Flux<Message> messagePublisher = messageListener.messagePublisher();
// prepare ConenctableFlux
ConnectableFlux<Message> connectableFlux = messagePublisher().publish();
// register subscribers
connectableFlux.subscribe(/* aConsumer */);
connectableFlux.subscribe(/* aCoreSubscriber */);
connectableFlux.subscribe(/* aSubscriber */);
// connect the ConnectableFlux to messagePublisher
connectableFlux.connect();
这篇关于将回调转换为被动发布者(Flux)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:将回调转换为被动发布者(Flux)
猜你喜欢
- Eclipse 的最佳 XML 编辑器 2022-01-01
- 转换 ldap 日期 2022-01-01
- 将 Java Swing 桌面应用程序国际化的最佳实践是什么? 2022-01-01
- 获取数字的最后一位 2022-01-01
- java.lang.IllegalStateException:Bean 名称“类别"的 BindingResult 和普通目标对象都不能用作请求属性 2022-01-01
- 在 Java 中,如何将 String 转换为 char 或将 char 转换 2022-01-01
- 未找到/usr/local/lib 中的库 2022-01-01
- GC_FOR_ALLOC 是否更“严重"?在调查内存使用情况时? 2022-01-01
- 如何使 JFrame 背景和 JPanel 透明且仅显示图像 2022-01-01
- 如何指定 CORS 的响应标头? 2022-01-01