【设计模式】发布订阅模式和观察者模式实现和区别

我总感觉这两个是一个东西,老是傻傻分不清楚,在写 vue 项目中的时候我们常用的还是发布订阅模式,比如使用事件总线 eventBus 就是发布订阅模式

发布-订阅模式(Pub-Sub Pattern)和观察者模式(Observer Pattern)是两种常见的软件设计模式,它们都涉及到对象间的通信和事件处理,但在实现方式和应用场景上有一些区别:

  1. 观察者模式

    • 在观察者模式中,有一个主题(Subject)和多个观察者(Observer)。主题维护着一个观察者列表,并提供方法用于注册和注销观察者,当主题状态发生变化时,它会通知所有的观察者。
    • 观察者模式通常是一对多的关系,一个主题可以有多个观察者,当主题状态改变时,所有观察者都会收到通知,并且采取相应的行动【调用观察者的update 方法】。
    • 直接的、点对点的通信,主题与观察者之间有直接的关联。
    • 手写一个观察者模式
  2. 发布-订阅模式

    • 在发布-订阅模式中,有一个发布者【emit】(Publisher)和多个订阅者【on】(Subscriber)。发布者和订阅者之间没有直接的联系,而是通过一个事件通道(Event Channel)进行通信。
    • 发布者将事件发布到事件通道中,订阅者可以通过订阅感兴趣的事件来接收通知。订阅者可以订阅多个不同的事件,并且可以随时取消订阅。
    • 手写一个发布订阅
相关推荐
全栈前端老曹10 小时前
【Redis】发布订阅模型 —— Pub/Sub 原理、消息队列、聊天系统实战
前端·数据库·redis·设计模式·node.js·全栈·发布订阅模型
资深web全栈开发10 小时前
设计模式之桥接模式 (Bridge Pattern)
javascript·设计模式·桥接模式
小温冲冲1 天前
通俗且详细讲解模板方法模式
设计模式·模板方法模式
reddingtons1 天前
Magnific AI:拒绝“马赛克”?AI 幻觉重绘流,拯救 1024px 废片
图像处理·人工智能·设计模式·新媒体运营·aigc·设计师·教育电商
知无不研1 天前
c++的设计模式(常用)
c++·观察者模式·单例模式·设计模式·简单工厂模式
李广坤1 天前
设计模式的本质:隔离变化
后端·设计模式
河码匠1 天前
设计模式之依赖注入(Dependency Injection)
java·设计模式·log4j
小湘西1 天前
互联网黑话持续更新
其他·设计模式
a3535413821 天前
设计模式——访问者模式
设计模式·访问者模式
Eloudy1 天前
动态库中不透明数据结构的设计要点总结
数据结构·设计模式