浅谈发布订阅和观察者模式,聊聊两者的区别
本篇文章给大家介绍一下发布订阅和观察者模式,聊聊两者的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
前段时间心血来潮自己写一一个promise, promise刚好就是订阅发布模式,工作中开发用的mobx 整体又是观察者模式,虽然都用,但一直没去细想两者的差异,网上的区别分析看的云里雾里。结合一下 整理一篇自己的总结和最简单实现(也因为简单 所以也很好理解)做个分享同时加深自己对这两者的理解
订阅发布
1、实现思路
- arr 做订阅了的事件的缓存中心
- 通过过on把需要做的事push arr 缓存数组中
- 等待事件触发时 依次emit执行事件
2、代码实现
interface eventHub { arr: Array<Function>; on(fn: Function): void; emit(): void; } interface Person { age: number; name: string; } let eventHub: eventHub = { arr: [] as Array<Function>, // 订阅 on(fn: Function) { this.arr.push(fn); }, // 发布 emit() { this.arr.forEach((fn) => fn()); }, }; let person: Person = {} as Person; eventHub.on(() => { //订阅的事件里判断当 person长度为2时 打印person, if (Object.keys(person).length == 2) { console.log(person); } }); setTimeout(function () { person.age = 27; //发布的时候去遍历 this.arr 并执行第一次 eventHub.emit(); }, 10); setTimeout(function () { person.name = "Zoe"; //发布的时候去遍历 this.arr 并执行第二次 eventHub.emit(); }, 20);
3、结果
虽然发布了两次 但最终on 里的console因为外部条件只执行了一次
观察者模式
1、实现思路
与观察者模式类似,但需要分一个观察者,和被观察者
- 观察者和被观察者存在关联,(内部基于发布订阅模式)
2、代码实现
// 被观察者 class Subject { name: string; //实例上定义一个name属性 state: string; observers: any[]; constructor(name:string) { this.name = name; this.observers = []; this.state = ""; } attach(o) { //传入观察者 this.observers.push(o); } setState(newState) { this.state = newState; this.observers.forEach((o) => o.update(this)); } } // 观察者 class Observer { name: string; constructor(name) { this.name = name; } update(interviewee) { console.log(`${interviewee.name} say to: ${this.name} ZOE的${interviewee.state}`); } } let hr = new Subject("HR"); let observer1 = new Observer("内推者"); let observer2 = new Observer("面试者"); hr.attach(observer1); hr.attach(observer2); hr.setState("面试通过了"); // baby.setState("面试没通过");
3、实现结果
两者的区别
eventHub 发布订阅
- on(订阅)和发布(emit)之间没有直接联系,是依赖中间的arr 做衔接 订阅一个push 到arr一个,emit的时候依次执行arr
观察者模式
- 观察者和被观察者存在关联,(内部基于发布订阅模式)
- 将观察者的实例作参数 传入被观察者的attach方法中 并缓存在observers 数组中
- 当观察者setState时候 依次调用缓存数组observers 中观察者的update方法
更多编程相关知识,请访问:编程视频!!
以上是浅谈发布订阅和观察者模式,聊聊两者的区别的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

如何在Phalcon框架中使用事件管理器(EventManager)实现观察者模式简介:事件管理器(EventManager)是Phalcon框架中强大且灵活的核心功能之一。通过使用事件管理器,您可以轻松实现观察者模式,以便在应用程序中实现对象之间的松耦合。本文将为您介绍如何使用Phalcon框架中的事件管理器实现观察者模式,并提供相应的代码示例。步骤一

导言PHP设计模式是一组经过验证的解决方案,用于解决软件开发中常见的挑战。通过遵循这些模式,开发者可以创建优雅、健壮和可维护的代码。它们帮助开发者遵循SOLID原则(单一职责、开放-封闭、Liskov替换、接口隔离和依赖反转),从而提高代码的可读性、可维护性和可扩展性。设计模式的类型有许多不同的设计模式,每种模式都有其独特的目的和优点。以下是一些最常用的php设计模式:单例模式:确保一个类只有一个实例,并提供一种全局访问此实例的方法。工厂模式:创建一个对象,而不指定其确切类。它允许开发者根据条件

1.什么是PHP设计模式?PHP设计模式是预定义的代码模板,旨在解决常见的软件开发问题。它们提供了经过验证的解决方案,可以提高代码的可重用性、可维护性和可扩展性。2.PHP设计模式的类型php中有许多不同的设计模式,每种模式都有其特定的用途。最常见的模式包括:单例模式:确保一个类只有一个实例。工厂模式:根据传给它的数据创建不同类型的对象。策略模式:允许程序在运行时更改其行为。观察者模式:允许对象订阅事件并在事件发生时获得通知。3.单例模式示例classSingleInstance{private

如何在PHP微服务中实现分布式消息发布和订阅,需要具体代码示例随着微服务架构的流行,分布式消息发布和订阅成为了构建可扩展性和高可用性微服务的重要组成部分。在PHP微服务中,使用消息队列可以实现这一特性。本文将介绍如何使用一个常见的消息队列工具RabbitMQ来实现分布式消息发布和订阅。首先,我们需要安装RabbitMQ并配置其连接。以下是一个简单的PHP脚本

提升Java编程技能:掌握适配器模式和观察者模式的实现方式,需要具体代码示例引言:在日常的软件开发中,我们常常需要处理不同类之间的兼容性问题,同时也需要实现各种用户界面的事件监听和处理。适配器模式和观察者模式是两种常用的设计模式,它们能够有效地解决这些问题。本文将详细介绍适配器模式和观察者模式的实现方式,并提供具体的Java代码示例,帮助读者更好地理解。一、

在Vue开发中,我们经常会遇到处理各种数据交互和组件通信的问题。其中一个常见的问题是如何处理发布订阅模式。发布订阅模式是一种常用的设计模式,用于解决组件之间的通信问题。在本文中,我将介绍如何处理Vue开发中遇到的发布订阅模式问题。首先,我们需要了解发布订阅模式的基本概念。发布订阅模式是一种一对多的关系,其中一个对象(发布者)发送消息,而其他对象(订阅者)接收

在现代软件开发中,设计模式是一种被广泛使用的概念。设计模式是存在于软件系统中的通用解决方案,它们经过测试和证明,可以帮助开发人员更高效地构建复杂的软件应用程序。观察者模式是其中一个很常见的设计模式,也是PHP开发者们需要掌握的一个重要的概念。在本文中,我们将介绍观察者模式的概念和实现方式,并演示如何在PHP应用程序中使用它。什么是观察者模式?观察者模式是一种

Java框架中的观察者模式通过接口和抽象类定义行为(1);Subject和Observer类实现管理和响应行为(2);Subject提供订阅和注销方法,维护观察者集合,并通知观察者(3)。示例中,Subject管理观察者并触发事件(4),ConcreteObserver响应事件(5)。
