前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >从观察者模式到Reactive Stream

从观察者模式到Reactive Stream

作者头像
dhyuan
发布2022-05-30 14:21:55
2290
发布2022-05-30 14:21:55
举报
文章被收录于专栏:响应式编程

Reactive 的系统就是通过实现回弹性、弹性能够对客户请求进行及时响应的系统。

正如 Reactive Manifesto 说的:

Systems built as Reactive Systems are more flexible, loosely-coupled and scalable.

说到松耦合,最基本的模式之一就算是“观察者模式”了。从观察者模式更进一步,可以衍生出“发布订阅模式”。较之前者,发布订阅模式多了一个‘事件通道’的角色。通过这个通道,使得订阅者不必知道发布者——两者解耦。Spring 在应用层面对“发布-订阅”模式进行了不错的支持(同步的、异步的),诸如@EventListener 等的日常用法参见: https://www.baeldung.com/spring-events https://reflectoring.io/spring-boot-application-events-explained/

响应式流 = 观察者 + 迭代器

从 Iterator 定义看,Iterator是一个“拉”模型,当我们需要数据时通过调用 next()拉取,hasNext()是查询是否还有数据可用。如果上游数据有什么异常情况,只能是通过 next()抛出的异常感知甚至感知不到。public interface Iterator { E next(); boolean hasNext(); }

以 RxJava 的 RxObserver 为例,感受下其接口语义上的改进:

代码语言:javascript
复制
public interface RxObserver<T> {
  void onNext(T next);
  void onComplete();
  void onError();
}

以 on 形式的前缀开头的方法名让我很明显的感受到一种“通知”的味道。上游组件告诉我们有新数据了、结束了、出错了!一种“推”的味道。

演进到这一步是不是就完美了呢?不。 如果 RxObserver 与上游组件是跨网络通信,那么我们可以想象每次的 onNext 通过网络一次处理一个数据的这种模式并不高效。而且 RxObserver 不能想上游表达自己的需求(比如需要几个数据?不再需要数据等),这就很容易延伸到 RxObserver 作为消费者的处理速度与上游不匹配时如何与上游协调工作这样的问题。 Reactive Stream 规范对以上需求进行了标准化,如下。其中 Subscription 就可用于向上游 Publisher 表达是否还需要、需要多少数据这样的请求。如果每次 request(1),整个模式就相当于“拉”模型;request(Integer.MAX_VALUE)就相当于“推”模型了。

代码语言:javascript
复制
public interface Publisher<T> {
    public void subscribe(Subscriber<? super T> s);
}

public interface Subscriber<T> {
    public void onSubscribe(Subscription s);
    public void onNext(T t);
    public void onError(Throwable t);
    public void onComplete();
}

public interface Subscription {
    public void request(long n);
    public void cancel();
}

public interface Processor<T, R> extends Subscriber<T>, Publisher<R> {
}

Reference:

https://github.com/reactive-streams/reactive-streams-jvm/blob/master/README.md

http://reactivex.io/

A Playful Introduction to Rx by Erik Meijer

https://www.baeldung.com/spring-events https://reflectoring.io/spring-boot-application-events-explained/

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-10-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 响应式编程 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档