观察者模式(Observer)
观察者模式是一种类之间的关系,不涉及到继承。
观察者模式很好理解,类似于邮件订阅和RSS 订阅,当我们浏览一
些博客或wiki 时,经常会看到RSS 图标,就这的意思是,当你订阅了该文章,如果后续有更新,会及
时通知你。其实,简单来讲就一句话:当一个对象变化时,其它依赖该对象的对象都会收到通知,并且
随着变化!对象之间是一种一对多的关系。先来看看关系图:
:MySubject 类就是我们的主对象,Observer1 和Observer2 是依赖于MySubject
的对象,当MySubject 变化时,Observer1 和Observer2 必然变化。AbstractSubject 类中定义着需要
监控的对象列表,可以对其进行修改:增加或删除被监控对象,且当MySubject 变化时,负责通知在
列表内存在的对象。我们看实现代码:
public interface Observer {
public void update();
}
public class Observer1 implements Observer{
@Override
public void update() {
// TODO 自动生成的方法存根
System.out.println("observer has received");
}
}
public class Observer2 implements Observer{
@Override
public void update() {
// TODO 自动生成的方法存根
System.out.println("observer2 has received!");
}
}
public interface Subject {
public void add(Observer observer);
public void del(Observer observer);
public void notifyObservers();
public void operation();
}
public abstract class AbstractSubject implements Subject{
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> enumo = vector.elements();
while(enumo.hasMoreElements()){
enumo.nextElement().update();
}
}
}
public class MySubject extends AbstractSubject{
public void operation(){
System.out.println("update self!");
notifyObservers();
}
}
public class ObserverTest {
public static void main(String[] args) {
Subject sub = new MySubject();
sub.add(new Observer1());
sub.add(new Observer2());
sub.operation();
}
}
- 抽象被观察者角色:也就是一个抽象主题,它把所有对观察者对象的引用保存在一个集合中,每个主题都可以有任意数量的观察者。抽象主题提供一个接口,可以增加和删除观察者角色。一般用一个抽象类和接口来实现。
- 抽象观察者角色:为所有的具体观察者定义一个接口,在得到主题通知时更新自己。
- 具体被观察者角色:也就是一个具体的主题,在集体主题的内部状态改变时,所有登记过的观察者发出通知。
- 具体观察者角色:实现抽象观察者角色所需要的更新接口,一边使本身的状态与制图的状态相协调。
观察者模式,顾名思义,就是一群观察者观察被观察者,被观察者属于稀有的一方,一般只有一个,而观察者有很多,时时刻刻观察着 被观察者,当被观察者有一点风吹草动的时候,观察者都能观察到,并作出相应的反应,观察者与被观察者都是有他们对应的抽象类来派生。