浅谈观察者模式

163 阅读2分钟

什么是观察者模式

观察者模式指的就是函数自动观察数据对象,如果对象一旦发生变化 那么函数就会自动执行, 观察者模式不仅被广泛应用于软件界面元素之间的交互,在业务对象之间的交互、权限管理等方面也有广泛的应用

观察者模式的实现方式

从根本上来说,该模式必须包含两个角色即观察者和被观察者对象。

一个对象发生变化时将自动通知其他对象,其他对象将做出反应。我们将发生改变的对象称为观察目标,将被通知的对象称为观察者

观察者和被观察者之间存在“观察”的逻辑关联,当被观察者发生改变的时候,观察者就会观察到这样的变化,并且做出相应的响应。

如果在用户界面、业务数据之间使用这样的观察过程,可以确保界面和数据之间划清界限,假定应用程序的需求发生变化,需要修改界面的表现,只需要重新构建一个用户界面,业务数据不需要发生变化。

观察者使用场景

当一个对象抽象模型有两个方面,其中一个方面依赖于另一方面。将这二者封装在独立的对象中使它们可以各自独立地改变和复用。

当对一个对象的改变需要同时改变其他对象,而不知道具体有多少对象需要被改变。

当一个对象必须通知其他对象,而它又不能假定其他对象是谁。换而言之,不希望这些对象时紧密耦合的。

观察者模式的特点

优点

观察者模式可以实现 表示层和数据逻辑层的分离,并降低观察目标和观察者之间的耦合度;

观察者模式支持简单广播通信,自动通知所有已经订阅过的对象;

观察者模式 符合开闭原则的要求;

观察目标和观察者之间的抽象耦合关系能够单独扩展

缺点

当一个观察目标有多个直接或间接的观察者时,通知所有观察者的过程将会花费很多时间。

当观察目标和观察者之间存在循环依赖时,观察目标会触发他们之间进行循环调用,可能导致系统崩溃。

观察者模式缺少相应机制,让观察者知道所观察的目标对象是怎么发生变化的,而仅仅只是知道观察目标发生了变化。