观察者模式的简单概念
假设现在有A、B、C、D等四个独立的对象,其中B、C、D这三个对象想在A对象发生改变的第壹时间知道这种改变,以便做出相应的响应。
上面的这种情形,就是观察者模式。当然每個被观察者可以有多个观察者,每個观察者也可以有多个被观察者。观察者与被观察者也不是对立的,壹個对象可以观察其他对象,也可以被其他对象观察
观察者模式的组成
抽象主题角色:把所有对观察者对象的引用保存在一个集合中,每个抽象主题角色都可以有任意数量的观察者。抽象主题提供一个接口,可以增加和删除观察者角色。一般用一个抽象类和接口来实现。
抽象观察者角色:为所有具体的观察者定义一个接口,在得到主题的通知时更新自己。
具体主题角色:在具体主题内部状态改变时,给所有登记过的观察者发出通知。具体主题角色通常用一个子类实现。
具体观察者角色:该角色实现抽象观察者角色所要求的更新接口,以便使本身的状态与主题的状态相协调。通常用一个子类实现。如果需要,具体观察者角色可以保存一个指向具体主题角色的引用。
简单例子
import java.util.Observable;
public class ExampleObservable extends Observable {
int data = 0;
public void setData(int data){
this.data = data;
this.setChanged();//标记此 Observable对象为已改变的对象
this.notifyObservers();//通知所有的观察者
}
}
import java.util.Observable;
import java.util.Observer;
public class ExampleObserver implements Observer {
//有被观察者发生变化,自动调用对应观察者的update方法
public void update(Observable object, Object argument) {
//通过强制类型转换获取被观察者对象
ExampleObservable example = (ExampleObservable)object;
System.out.println("example.data changed, the new value of data is " + example.data);
}
}
public class Main {
public static void main(String[] args) {
ExampleObservable example = new ExampleObservable();
example.addObserver(new ExampleObserver());//给example这个被观察者添加观察者,允许添加多個观察者
example.setData(2);
example.setData(-5);
example.setData(9999);
}
}
既是观察者又是被观察者
import java.util.Observable;
import java.util.Observer;
public class ObserverB extends Observable implements Observer {
int data = 0;
public void update(Observable object, Object arg) {
System.out.println("ObserverB found that ObserverA changed...");
}
public void setData(int data){
this.data = data;
this.setChanged();
this.notifyObservers();
}
}
import java.util.Observable;
import java.util.Observer;
public class ObserverA extends Observable implements Observer {
public void update(Observable object, Object arg) {
ObserverB observerB = (ObserverB)object;
System.out.println("observerB changed, the new value of observerB.data is " + observerB.data);
this.setChanged();
this.notifyObservers();
}
}
public class Main1 {
public static void main(String[] args) {
ObserverA a = new ObserverA();
ObserverB b = new ObserverB();
a.addObserver(b);
b.addObserver(a);
b.setData(2);
}
}