发布订阅模式和观察者模式有何本质区别?
- 内容介绍
- 相关推荐
本文共计1296个文字,预计阅读时间需要6分钟。
本篇文章为大家简要介绍以下内容:发布订阅和观察者模式。这两种模式在软件设计中广泛应用,用于实现对象之间的解耦和通信。以下是两者的区别:
发布订阅模式:- 发布者发布消息,订阅者订阅特定消息。- 发布者和订阅者之间无需直接交互,解耦度高。- 适用于消息传递、事件处理等场景。
观察者模式:- 观察者对象对目标对象的状态变化感兴趣。- 当目标对象状态变化时,通知所有观察者对象。- 观察者模式强调对象之间的依赖关系。
两者区别:- 发布订阅模式更侧重于消息传递,而观察者模式更侧重于状态变化的通知。- 发布订阅模式中,发布者和订阅者之间没有直接的依赖关系,而观察者模式中,观察者和目标对象之间存在依赖关系。
参考价值:- 了解这两种模式有助于提高代码的可维护性和可扩展性。- 在实际开发中,可以根据具体需求选择合适的模式。
如有需要,可参考以下朋友的观点:- 朋友A:我认为发布订阅模式更适合处理复杂的消息传递场景。- 朋友B:观察者模式在实现状态变化通知时更为简单直接。
希望这些信息对大家有所帮助。
本篇文章给大家介绍一下发布订阅和观察者模式,聊聊两者的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。前段时间心血来潮自己写一一个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方法
更多编程相关知识,请访问:编程视频!!
以上就是浅谈发布订阅和观察者模式,聊聊两者的区别的详细内容,更多请关注自由互联其它相关文章!
本文共计1296个文字,预计阅读时间需要6分钟。
本篇文章为大家简要介绍以下内容:发布订阅和观察者模式。这两种模式在软件设计中广泛应用,用于实现对象之间的解耦和通信。以下是两者的区别:
发布订阅模式:- 发布者发布消息,订阅者订阅特定消息。- 发布者和订阅者之间无需直接交互,解耦度高。- 适用于消息传递、事件处理等场景。
观察者模式:- 观察者对象对目标对象的状态变化感兴趣。- 当目标对象状态变化时,通知所有观察者对象。- 观察者模式强调对象之间的依赖关系。
两者区别:- 发布订阅模式更侧重于消息传递,而观察者模式更侧重于状态变化的通知。- 发布订阅模式中,发布者和订阅者之间没有直接的依赖关系,而观察者模式中,观察者和目标对象之间存在依赖关系。
参考价值:- 了解这两种模式有助于提高代码的可维护性和可扩展性。- 在实际开发中,可以根据具体需求选择合适的模式。
如有需要,可参考以下朋友的观点:- 朋友A:我认为发布订阅模式更适合处理复杂的消息传递场景。- 朋友B:观察者模式在实现状态变化通知时更为简单直接。
希望这些信息对大家有所帮助。
本篇文章给大家介绍一下发布订阅和观察者模式,聊聊两者的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。前段时间心血来潮自己写一一个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方法
更多编程相关知识,请访问:编程视频!!
以上就是浅谈发布订阅和观察者模式,聊聊两者的区别的详细内容,更多请关注自由互联其它相关文章!

