博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
设计模式-观察者模式(Observer)
阅读量:4290 次
发布时间:2019-05-27

本文共 2454 字,大约阅读时间需要 8 分钟。

观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态上发生变化时,会通知所有观察者对象,让他们能够自动更新自己。

观察者模式的组成:

  • 抽象主题角色:把所有对观察者对象的引用保存在一个集合中,每个抽象主题角色都可以有任意数量的观察者。抽象主题提供一个接口,可以增加和删除观察者角色。一般用一个抽象类或接口来实现。
  • 抽象观察者角色:为所有具体的观察者定义一个接口,在得到主题的通知时更新自己。
  • 具体主题角色:在具体内部状态改变时,给所有登记过的观察者发出通知。具体主题角色通常用一个子类实现。
  • 具体观察者角色:该角色实现抽象观察者角色所需要的更新接口,以便使本身的状态与主题的状态相协调。如果需要,具体观察者角色可以保存一个指向具体主题角色的引用。通常用一个子类实现。

具体实现:

抽象主題角色:

public interface Watched {  void addWatcher(Watcher watcher);  void removeWatcher(Watcher watcher);  void notifyWatchers(String string);}

抽象观察者角色:

public interface Watcher {  void update(String string);}

具体主题角色:

public class ConcreteWatched implements Watched {
private List
list = new ArrayList<>(); @Override public void addWatcher(Watcher watcher) { list.add(watcher); } @Override public void removeWatcher(Watcher watcher) { list.remove(watcher); } @Override public void notifyWatchers(String str) { list.forEach(item -> item.update(str)); }}

具体观察者角色:

public class ConcreteWatcher implements Watcher {
@Override public void update(String str) { System.out.println(str); }}

测试运行代码:

public class Test {  public static void main(String[] args) {    Watched girl = new ConcreteWatched();    Watcher watcher1 = new ConcreteWatcher();    Watcher watcher2 = new ConcreteWatcher();    Watcher watcher3 = new ConcreteWatcher();    girl.addWatcher(watcher1);    girl.addWatcher(watcher2);    girl.addWatcher(watcher3);    girl.notifyWatchers("hello world");    girl.removeWatcher(watcher2);    girl.notifyWatchers("world");  }}

对于观察者模式,jdk内置实现了这种设计模式:

class HuiWatched extends Observable {
void counter(int number) { for (;number>=0;number--) { this.setChanged(); this.notifyObservers(number); } }}class Watcher1 implements Observer {
@Override public void update(Observable o, Object arg) { System.out.println("Watcher1's count is: " + arg); }}class Watcher2 implements Observer {
@Override public void update(Observable o, Object arg) { if ((Integer) arg <= 5) { System.out.println("Watcher2's count is : " + arg); } }}public class TwoObservers {
public static void main(String[] args) { HuiWatched huiWatched = new HuiWatched(); Watcher1 watcher1 = new Watcher1(); Watcher2 watcher2 = new Watcher2(); huiWatched.addObserver(watcher1); huiWatched.addObserver(watcher2); huiWatched.counter(10); }}

具体的使用方法和上述的实现类似,这里需要注意的是jdk内置的实现多了一个对主题状态的修改,当有修改的时候状态会改变,当观察者被通知的时候状态会恢复。

转载地址:http://hmrgi.baihongyu.com/

你可能感兴趣的文章
热点数据降级详解(storm+nginx+lua)
查看>>
加载更多功能实现
查看>>
React相关Dom约束性和非约束性操作
查看>>
Hystrix高可用架构介绍
查看>>
netty源码分析之-SimpleChannelInboundHandler与ChannelInboundHandlerAdapter详解(6)
查看>>
netty源码分析之-开发过程中重要事项分析(7)
查看>>
Sublime Text3插件详解
查看>>
netty源码分析之-ByteBuf详解(8)
查看>>
javascript函数定义三种方式详解
查看>>
javascript中this关键字详解
查看>>
javascript关于call与apply方法详解
查看>>
netty源码分析之-ReferenceCounted详解(9)
查看>>
javascript闭包详解
查看>>
javascript类的创建与实例对象
查看>>
javascript原型详解(1)
查看>>
netty源码分析之-处理器详解(9)
查看>>
javascript原型对象存在的问题(3)
查看>>
javascript原型继承(1)
查看>>
javascript原型继承-实现extjs底层继承(2)
查看>>
javascript设计模式-建立接口的方式(1)
查看>>