美文网首页
观察者模式

观察者模式

作者: quanCN | 来源:发表于2019-08-01 00:17 被阅读0次

定义

观察者模式是对象的行为模式,又叫发布-订阅(Publish/Subscribe)模式,模型-视图-模式(Model/View)模式,源-监听器(Source/Listener)模式或从属者(dependents)模式。

一个软件系统常常要求在某一个对象的状态发生改变的时候某些其它的对象做出相应的改变,观察者模式是满足这一要求的最重要的一种方案。
根据观察者对象的引用位置,观察者模式分为两种



  • 这种实现在传统的模式著作和讨论中比较常见



  • java提供的观察者模型就属于这种

观察者模式的结构

第一种结构

第一种实现的模式如下


  • 抽象主题(Subject)角色
    主题角色把所有对观察者对象的引用保存在一个集合(比如Vector对象)里,每一个主题都可以有任意数量的观察者。抽象主题提供一个接口,可以增加和删除观察者对象,主题角色又叫抽象被观察者角色
    public interface Subject {
        /**
         * 注册一个新的观察者对象
         * @param observer 观察者
         */
        void attach(Observer observer);
        /**
         * 删除该观察者
         * @param observer 要删除的观察者对象
         */
        void detach(Observer observer);
        /**
         * 通知全部已经注册过的观察者
         */
        void notifyObservers();
    }
    
  • 抽象观察者(Observer)角色
    为所有具体的观察者定义一个接口,在得到主题的通知时时更新自己,这个接口叫做更新接口
    public interface Observer {
        /**
         * 观察者更新方法
         */
        void update();
    }
    
  • 具体主题(ConcreteSubject)角色
    拥有全部的观察者对象集合,在具体主题的内部状态改变时,给所有的观察者发送通知。具体主题角色又叫具体被观察角色
    public class ConcreteSubject implements Subject{
        private Vector observersVector = new Vector();
        public void attach(Observer observer) {
            observersVector.addElement(observer);
        }
        public void detach(Observer observer) {
            observersVector.removeElement(observer);
        }
        public void notifyObservers() {
            Enumeration enumeration = observers();
            while (enumeration.hasMoreElements()){              
                ((Observer)enumeration.nextElement()).update();
            }
        }
        private Enumeration observers(){
            return ((Vector)observersVector.clone()).elements();
        }
    }
    
  • 具体观察者(ConcreteObserver)角色
    具体观察者角色实现实现抽象观察者所要求的更新接口
    public class ConcreteObserver  implements Observer{
        public void update() {
            System.out.println("I am notified");
        }
    }
    
  • 测试
    public class MySubject extends ConcreteSubject {
        public void change(){
            System.out.println("data change...");
            notifyObservers();
        }
    }
    
    public class ObserverTest {
        Observer observerA;
        Observer observerB;
        MySubject subject;
    
        @Before
        public void before(){
            observerA = new ConcreteObserver();
            observerB = new ConcreteObserver();
            subject = new MySubject();
            subject.attach(observerA);
            subject.attach(observerB);
        }
        @Test
        public void testObserver(){
            subject.change();
        }
    }
    

第二种结构

第二种实现的模式如下



第二中与第一种基本相同

  • 抽象主题角色
    subject类可以用抽象类或类实现
    public abstract class Subject {
        private Vector observersVector = new Vector();
    
        public void attach(Observer observer) {
            observersVector.addElement(observer);
        }
    
        public void detach(Observer observer) {
            observersVector.removeElement(observer);
        }
    
        public void notifyObservers() {
            Enumeration enumeration = observers();
            while (enumeration.hasMoreElements()){
                ((Observer)enumeration.nextElement()).update();
            }
        }
        private Enumeration observers(){
            return ((Vector)observersVector.clone()).elements();
        }
    }
    
  • 具体主题角色
    public class ConcreteSubject extends Subject {
        private String data;
        public void change(String newData){
            data = newData;
            System.out.println("data change");
            notifyObservers();
        }
    }
    
  • 抽象观察者和具体观察者代码与第一种结构完全相同
  • 测试
    public class ObserverTest {
        Observer observerA;
        Observer observerB;
        ConcreteSubject subject;
        @Before
        public void before(){
            observerA = new ConcreteObserver();
            observerB = new ConcreteObserver();
            subject = new ConcreteSubject();
            subject.attach(observerA);
            subject.attach(observerB);
        }
        @Test
        public void testObserver(){
            subject.change("test");
        }
    }
    

全部代码

相关文章

  • 11.9设计模式-观察者模式-详解

    设计模式-观察者模式 观察者模式详解 观察者模式在android中的实际运用 1.观察者模式详解 2.观察者模式在...

  • RxJava基础—观察者模式

    设计模式-观察者模式 观察者模式:观察者模式(有时又被称为发布(publish )-订阅(Subscribe)模式...

  • 前端面试考点之手写系列

    1、观察者模式 观察者模式(基于发布订阅模式) 有观察者,也有被观察者。 观察者需要放到被观察者列表中,被观察者的...

  • RxJava 原理篇

    一、框架思想 观察者模式观察者自下而上注入被观察者被观察者自上而下发射事件观察者模式 装饰器模式自上而下,被观察者...

  • 观察者模式

    观察者模式概念 观察者模式是对象的行为模式,又叫作发布-订阅(publish/subscrible)模式。 观察者...

  • 设计模式-观察者模式

    观察者模式介绍 观察者模式定义 观察者模式(又被称为发布-订阅(Publish/Subscribe)模式,属于行为...

  • 观察者模式

    观察者模式 观察者模式的定义 观察者模式(Observer Pattern)也叫做发布订阅模式(Publish/s...

  • iOS设计模式之观察者模式

    观察者模式 1、什么是观察者模式 观察者模式有时又被称为发布(publish)-订阅(Subscribe)模式、模...

  • 观察者模式和发布订阅模式区别

    观察者模式 所谓观察者模式,其实就是为了实现松耦合(loosely coupled)。 在观察者模式中,观察者需要...

  • RxJava(二)

    一、观察者模式 1.1、传统的观察者模式 1.2、RxJava 的观察者模式 区别传统的观察者模式是一个 Obse...

网友评论

      本文标题:观察者模式

      本文链接:https://www.haomeiwen.com/subject/pwhfdctx.html