【设计模式】观察者模式
来源:互联网 发布:手机淘宝怎么登录不上 编辑:程序博客网 时间:2024/05/21 01:29
观察者模式是对象的行为模式,又叫发布-订阅(Publish/Subscribe)模式、模型-视图(Model/View)模式、源-监听器(Source/Listener)模式或从属者(Dependents)模式。
观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态上发生变化时,会通知所有观察者对象,使它们能够自动更新自己。
我们模拟广播的过程,主题类和观察者类,分别是信号站和收音机。当信号站发出信号后所有收音机都可以接到信号。
观察者模式所涉及的角色有:
● 抽象主题(Subject)角色:抽象主题角色把所有对观察者对象的引用保存在一个聚集(比如ArrayList对象)里,每个主题都可以有任何数量的观察者。抽象主题提供一个接口,可以增加和删除观察者对象,抽象主题角色又叫做抽象被观察者(Observable)角色。
● 具体主题(ConcreteSubject)角色:将有关状态存入具体观察者对象;在具体主题的内部状态改变时,给所有登记过的观察者发出通知。具体主题角色又叫做具体被观察者(Concrete Observable)角色。
● 抽象观察者(Observer)角色:为所有的具体观察者定义一个接口,在得到主题的通知时更新自己,这个接口叫做更新接口。
● 具体观察者(ConcreteObserver)角色:存储与主题的状态自恰的状态。具体观察者角色实现抽象观察者角色所要求的更新接口,以便使本身的状态与主题的状态 像协调。如果需要,具体观察者角色可以保持一个指向具体主题对象的引用。
抽象主题类(保存订阅者的数组,并且提供新增订阅者,删除订阅者,通知订阅者三个功能,并且抽象public方法提供调用)
package observer.sub;import java.util.Enumeration;import java.util.Vector;import observer.Observer;public abstract class AbstractSubject { //用来保存多个观察者 private Vector<Observer> vector = new Vector<Observer>(); public void add(Observer observer) { vector.add(observer); } public void del(Observer observer) { vector.remove(observer); } public void notifyObservers() { Enumeration<Observer> elements = vector.elements(); while (elements.hasMoreElements()) { elements.nextElement().update(); } } public abstract void operation() ;}
实现主题类(调用public方法实现通知订阅者的功能)
package observer.sub;public class MySubject extends AbstractSubject {public void operation() {System.out.println("update self!");notifyObservers();}}
订阅者接口统一实现
package observer;public interface Observer {public void update();}
分别做两个实现,订阅者1和订阅者2
package observer;public class Observer1 implements Observer {@Overridepublic void update() {System.out.println("observer1");}}
package observer;public class Observer2 implements Observer {@Overridepublic void update() {System.out.println("observer2");}}
测试类;(创建主题类,然后添加订阅者,接着调public方法通知订阅方法,当主题类发生变更的时候,所有的订阅类都会发生变化)
import observer.Observer1;import observer.Observer2;import observer.sub.AbstractSubject;import observer.sub.MySubject;public class ObserverTest {public static void main(String[] args) {AbstractSubject sub = new MySubject();sub.add(new Observer1());sub.add(new Observer2());sub.operation();}}
上面的过程是推模式,不管订阅者是否需要全部信息,当主题类变化的时候,订阅者都会收到通知。
我们现在把上面的模型改成拉模式,也就是订阅者主动调用接口方法来获取消息,而不是由主题类自己推送消息。
- 模式设计:观察者模式
- 设计模式-----观察者模式
- 设计模式-观察者模式
- 设计模式--观察者模式
- 设计模式:观察者模式
- 设计模式-----观察者模式
- 设计模式:观察者模式
- 设计模式-观察者模式
- 设计模式 观察者模式
- 设计模式-观察者模式
- 设计模式-【观察者模式】
- 设计模式-观察者模式
- 设计模式 -- 观察者模式
- 设计模式-观察者模式
- 【设计模式】观察者模式
- 设计模式- 观察者模式
- 设计模式- 观察者模式
- 设计模式--观察者模式
- 上机考真题练习
- Android NDK重定向std::cout输出到log
- Divein_day04 vi 下了解代码解析过程
- Java 内存区域和GC机制
- Android自定义控件HintSeekBar开发(一)
- 【设计模式】观察者模式
- 经典并查集之畅通工程
- 条款19 设计class 犹如设计type
- 前端开发---前端相关软件分享
- win8系统下安装SQL2005(SQL Server 2005)图文教程
- MapReduce原理与设计思想
- Hibernate Error
- test _bs
- IOS开发—多线程简介