java 多线程系列文章列表, 请查看目录: 《java 多线程学习笔记》
1. java9 的发布订阅
java9 新增了一个发布-订阅框架, 该框架是基于异步响应流的. 之前开发发布订阅通常都会借助于中间件, 如mq, redis 等, java9之后, 对于简单的发布订阅系统, jdk便直接可以满足.
1.1 相关API
- Flow.Pulisher: 消息的生产者, 发布者
- Flow.Subscriber: 数据的订消费者, 订阅者
- Flow.Subscription: 订阅者与发布者直接的连接通道, 订阅者可通过request方法获取数据项, 也可通过cancel 方法取消订阅
- Flow.Processor: 数据处理器, 可同时被发布者和订阅者使用.
1.2 消费者接口-Flow.Subscriber:
自定义消费者时, 需要实现Flow.Subscriber 接口, 并重写以下四个方法:
- public void onSubscribe(Flow.Subscription subscription): 订阅者注册成功时, 自动触发. 当发布者发布一条消息时, 才会触发.
- public void onNext(T item): 获取到数据时, 触发该方法
- public void onError(Throwable throwable): 订阅失败时, 触发
- public void onComplete(): 订阅结束时触发. 当发布者关闭时, 订阅结束.
2. 发布订阅测试
2.1 订阅者
public class MySubscriber<T> implements Flow.Subscriber<T> {
// 发布者
private Flow.Subscription subscription;
// 名称
private String name;
public MySubscriber(String name) {
this.name = name;
}
@Override
public void onSubscribe(Flow.Subscription subscription