详解Guava中EventBus的使用

作者:指北君 时间:2021-09-13 07:36:34 

Guava EventBus

EventBus是Guava的事件处理机制,是设计模式中观察者模式(生产/消费者编程模型)的优雅实现。对于事件监听和发布订阅模式,EventBus使用非常简单便捷。

详解Guava中EventBus的使用

如果你做过CS的开发,下面这段代码可能会比较熟悉。

Button button = new Button("确定");

button.addListener( new Listener(){
    ...
    public void onClick(Event event){
        // 
    }
    ...
} );

为按钮注册事件监听,当按钮被点击时,则触发监听中相应的回调。在上面的代码中,有三个角色事件(Event),事件源(Button),监听(Listener),按钮作为事件源,当点击行为触发时,会将该行为封装成对应的点击事件,并根据行为类型将事件传递到响应的 * 上, 这也就是我们常说的 * 模式。

使用场景

实现消息生产者与消费者间的解耦,对应事件源与 * ,而消息则是事件

通过事件驱动业务流程扭转,通过异步执行机制实现代码非阻塞执行

扩展主线外的分支业务,减少代码的侵入,比如各个环节的消息通知、短信提醒等

实现消息广播到不同的模块中

示例

订单支付时的消息发送

// 商品
public class ProductOrder {
    private String user; // 用户
    private String product; // 商品
    private double amount; // 金额
    @Override
    public String toString() {
        return String.format("用户:%s购买了商品:%s,总金额:%s", user, product, amount);
    }
}
// 事件
    @Data
    @AllArgsConstructor
    public static class CreateOrderEvent implements OrderEvent{
        private ProductOrder order;
    }
// 监听
    public static class CreateOrderListener{
        @Subscribe
        public void onEvent(CreateOrderEvent event) {
            log.info("创建订单:{}", event.getOrder());
        }
    }

测试: 我们可以定义各种事件,比如订单创建、订单取消、订单支付... 只需要简单的三个步骤即可:

// 1. 创建事件总线
    EventBus eventBus = new EventBus( ProductOrder.class.getName() );
// 2. 注册事件监听
    eventBus.register( new CreateOrderListener() );
    eventBus.register( new PayOrderListener() );
    eventBus.register( new CancelOrderListener() );
    eventBus.register( new RenewOrderListener() );
// 3. 发送事件通知
    eventBus.post(new ProductOrder.CreateOrderEvent(order));
    TimeUnit.SECONDS.sleep(1);
    eventBus.post(new ProductOrder.CancelOrderEvent(order));
    TimeUnit.SECONDS.sleep(1);
    eventBus.post(new ProductOrder.RenewOrderEvent(order));
    TimeUnit.SECONDS.sleep(1);
    eventBus.post(new ProductOrder.PayOrderEvent(order));
    TimeUnit.SECONDS.sleep(5);
    eventBus.post(new ProductOrder.ReturnOrderEvent(order));

同时我们可以通过AsyncEventBus建立事件异步总线,这样在事件被触发时,可以异步通知监听者完成事件回调,以此来提高响应速度。

核心

EventBus

事件总线,可以理解为事件与 * 的上下文,主要实现事件的注册、事件的分发、以及 * 的回调,主要提供的方法包括:

  • register 注册监听,将 * 注册到事件总线,通过注解@Subscribe通知其监听的事件类型(第一个方法参数类型)

  • unregister 卸载监听,从事件总线移除监听

  • post 发送事件通知,根据post事件类型,找到所有订阅了该类型事件的 * ,并将事件推送到 * 对应的监听方法

Subscribe

通过@Subscribe标识 * 所关注的事件类型

Event

可以是任何对象,当然不建议将基础类型或String作为事件类型,这样就没法做到按类型区分了

详解Guava中EventBus的使用

通过上面的图就可以很清楚各个各个组件的职责,以及如何通过事件总线完成事件向监听的传播,最终基于事件回调机制完成消息传递。基于事件驱动的服务模型

上面这种结构的图形是不是在很多位置都见过,这是一种经典的设计模式。试想一下,我们不通过事件驱动行为时,一般你们怎么写代码,通过ifelse?或者其他有着异曲同工的 实现方法,目的最后都是一样。基于Guava提供的工具,我们不仅在使用时只需要简单的三个步骤就能实现,同样,当需要屏蔽该功能时只需要去掉register一行即可,对整体功能 也没有任何的影响。

在我们引入某种设计模式,某种架构模型时,总的目的都是为了降低代码模块间的耦合度,提升代码整体的可读性,最终让代码能够易于维护性,或者有一定的复用性。

来源:https://mp.weixin.qq.com/s/dqbnN5YmfWSZVUK4EcASPg

标签:Guava,EventBus
0
投稿

猜你喜欢

  • java中Swing会奔跑的线程侠

    2021-12-14 23:47:36
  • selenium+java破解极验滑动验证码的示例代码

    2022-11-19 21:52:01
  • Java IO流和文件操作实现过程解析

    2022-03-10 02:08:13
  • MyBatis在注解上使用动态SQL方式(@select使用if)

    2023-09-24 06:52:55
  • Java源码解析HashMap成员变量

    2023-04-24 07:20:22
  • docker 的java编译环境构建详细介绍

    2023-02-10 04:08:30
  • Spring FreeMarker整合Struts2过程详解

    2023-03-01 00:30:52
  • SpringBoot集成kaptcha验证码

    2023-06-26 03:56:17
  • idea快速搭建spring cloud注册中心与注册的方法

    2023-03-09 17:40:35
  • 如何在Unity中检测死循环和卡死

    2023-12-18 00:55:17
  • Java实现驼峰、下划线互转的方法

    2023-08-18 09:17:54
  • C#实现JSON字符串序列化与反序列化的方法

    2023-12-01 12:40:23
  • Android自定义TextView跑马灯效果

    2023-08-07 01:14:57
  • 使用JAVA实现邮件发送功能的图文教程

    2021-09-04 17:29:36
  • 25行Java代码将普通图片转换为字符画图片和文本的实现

    2023-11-24 02:04:26
  • springboot相关面试题汇总详解

    2023-10-06 17:16:11
  • 新手Hadoop安装 环境搭建

    2022-12-15 05:34:02
  • java GUI编程之paint绘制操作示例

    2023-11-24 17:58:39
  • 解析maven的用法和几个常用的命令(推荐)

    2022-04-16 23:31:15
  • Java 常量池详解之字符串常量池实现代码

    2022-09-09 22:12:03
  • asp之家 软件编程 m.aspxhome.com