[设计模式]观察者模式(Observer)
2017-05-14 17:49
351 查看
观察者模式是类和类之间的关系,不涉及到继承,学的时候应该 记得归纳。观察者模式很好理解,类似于邮件订阅和RSS订阅(站点用来和其他站点之间共享内容的一种简易方式,即Really Simple Syndication(简易信息聚合)),当我们浏览一些博客或wiki时,经常会看到RSS图标,就这的意思是,当你订阅了该文章,如果后续有更新,会及时通知你。其实,简单来讲就一句话:当一个对象变化时,其它依赖该对象的对象都会收到通知,并且随着变化!对象之间是一种一对多的关系。先来看看关系图:
我解释下这些类的作用:MySubject类就是我们的主对象,Observer1和Observer2是依赖于MySubject的对象,当MySubject变化时,Observer1和Observer2必然变化。AbstractSubject类中定义着需要监控的对象列表,可以对其进行修改:增加或删除被监控对象,且当MySubject变化时,负责通知在列表内存在的对象。我们看实现代码:
一个Observer接口和两个实现类:
public interface Observer {
public void update();
}
Subject接口及实现类:
/**
* @author binkang
* @date May 14, 2017
*/
public interface Subject {
//添加观察者
void add(Observer observer);
//删除观察者
void delete(Observer observer);
//通知所有观察者
void notifyObservers();
//自身的操作
void operation();
}
/**
* @author binkang
* @date May 14, 2017
*/
public class MySubject extends AbstractSubject {
public void operation() {
System.out.println("subject update self");
notifyObservers();
}
public static void main(String[] args) {
Subject sub = new MySubject();
sub.add(new Observer1());
sub.add(new Observer2());
sub.operation();
}
}输出:
update self!
observer1 has received!
observer2 has received!
我解释下这些类的作用:MySubject类就是我们的主对象,Observer1和Observer2是依赖于MySubject的对象,当MySubject变化时,Observer1和Observer2必然变化。AbstractSubject类中定义着需要监控的对象列表,可以对其进行修改:增加或删除被监控对象,且当MySubject变化时,负责通知在列表内存在的对象。我们看实现代码:
一个Observer接口和两个实现类:
public interface Observer {
public void update();
}
public class Observer1 implements Observer { @Override public void update() { System.out.println("observer1 has received!"); } }
/** * @author binkang * @date May 14, 2017 */ public class Observer2 implements Observer{ public void update() { System.out.println("observer2 has received"); } }
Subject接口及实现类:
/**
* @author binkang
* @date May 14, 2017
*/
public interface Subject {
//添加观察者
void add(Observer observer);
//删除观察者
void delete(Observer observer);
//通知所有观察者
void notifyObservers();
//自身的操作
void operation();
}
/** * @author binkang * @date May 14, 2017 */ public abstract class AbstrackSubject implements Subject{ private Vector<Observer> vec = new Vector<Observer>(); public void add(Observer observer) { vec.add(observer); } public void delete(Observer observer) { vec.remove(observer); } public void notifyObservers() { for(Observer observer: vec) { observer.update(); } } }
/**
* @author binkang
* @date May 14, 2017
*/
public class MySubject extends AbstractSubject {
public void operation() {
System.out.println("subject update self");
notifyObservers();
}
public static void main(String[] args) {
Subject sub = new MySubject();
sub.add(new Observer1());
sub.add(new Observer2());
sub.operation();
}
}输出:
update self!
observer1 has received!
observer2 has received!
相关文章推荐
- 设计模式之观察者模式(Observer Pattern)(一)
- Java设计模式之Observer(观察者)模式
- java设计模式学习系列之六:Observer, 观察者模式---小例
- 设计模式笔记--行为型模式之七Observer--观察者
- 设计模式笔记 18. Observer 观察者模式(行为型模式)
- IssueVision 学习笔记(三)-----设计模式之OBSERVER(观察者)模式
- 设计模式学习2——观察者模式(Observer)
- 我读设计模式之观察者模式(Observer Pattern)
- 设计模式之观察者(Observer)模式与其C++通用实现(上)
- 设计模式理解 - 伟大的【Observer 观察者模式】
- C#设计模式-观察者observer模式实现
- .NET实用设计模式:观察者模式(Observer)
- 设计模式与泡mm的关系之Observer观察者模式及再思考
- 设计模式之Observer(观察者)
- 设计模式之观察者模式(Observer Pattern)(二)
- 乐在其中设计模式(C#) - 观察者模式(Observer Pattern)
- 乐在其中设计模式(C#) - 观察者模式(Observer Pattern)
- 设计模式之观察者Observer
- 观察者设计模式Observer
- 设计模式之Observer观察者模式