21. java9 的发布订阅

Java9引入了一个异步响应流的发布订阅框架,无需依赖中间件即可实现简单系统。Flow.Publisher作为消息生产者,Flow.Subscriber作为数据消费者,并通过Flow.Subscription建立连接。在自定义消费者时,需实现Flow.Subscriber接口并重写四个关键方法。测试表明,生产者启动时才建立订阅连接,所有订阅者都能接收到消息,生产者关闭时订阅结束,且订阅者仅接收订阅后的消息。
摘要由CSDN通过智能技术生成

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
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值