前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【EventBus】发布-订阅模式 ( EventBus 组成模块 | 观察者模式 )

【EventBus】发布-订阅模式 ( EventBus 组成模块 | 观察者模式 )

作者头像
韩曙亮
发布2023-03-29 17:43:10
3470
发布2023-03-29 17:43:10
举报

文章目录

一、发布-订阅模式


发布订阅模式 :

  • 发布者 Publisher : 状态改变时 , 向 消息中心 发送事件 ;
  • 订阅者 Subscriber : 到 消息中心 订阅自己关心的事件 ;
  • 消息中心 : 负责维护一个 消息队列 , 根据 消息类型 将 消息 转发给 对应的 订阅者 ;
在这里插入图片描述
在这里插入图片描述

二、EventBus 组成模块


EventBus 中有以下几个组成部分 :

  • Publisher 发布者 : 调用 post 方法发布事件 ;
  • EventBus 事件总线 : 该模块接收 发布者发布的事件 , 将事件转发给对应的 Subscriber 订阅者 ;
  • Subscriber 订阅者 : 使用 @Subscriber 注解修饰 , 接收发布的事件 , 并处理事件 ;
  • Event 事件 : 自定义类型 , 通过不同的事件类型 , 确定事件应该发送给哪个订阅者 ;
在这里插入图片描述
在这里插入图片描述

EventBus 是 发布 - 订阅 模式 的事件总线框架 , 事件的 发布者 与 订阅者 实现了解耦 , 简化了 Android 中各个组件之间的通信 ;

三、观察者模式


观察者模式中 , 目标对象 ( Subject / 被观察者 ) 中 , 维护了多个 观察者 , 观察者需要注册到 目标对象 中 , 如果目标对象发生改变 , 通知所有的观察者 , 观察者对象 收到通知后 , 进行相关处理 ;

在这里插入图片描述
在这里插入图片描述

上述结构中 , 观察者 与 目标对象 ( 被观察者 ) 是有 耦合性 的 ;

发布 - 订阅 模式 中 , 发布者 和 订阅者 是完全解耦的 ;

发布 - 订阅 模式 比 观察者模式 多了一个消息中心 , 这个 消息中心 是 发布者 和 订阅者 之间解耦的关键 ;

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-09-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、发布-订阅模式
  • 二、EventBus 组成模块
  • 三、观察者模式
相关产品与服务
事件总线
腾讯云事件总线(EventBridge)是一款安全,稳定,高效的云上事件连接器,作为流数据和事件的自动收集、处理、分发管道,通过可视化的配置,实现事件源(例如:Kafka,审计,数据库等)和目标对象(例如:CLS,SCF等)的快速连接,当前 EventBridge 已接入 100+ 云上服务,助力分布式事件驱动架构的快速构建。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档