1. Java自带的实现

类图

/**
* 观察目标 继承自 java.util.Observable
* @author stone
*
*/
public class UpdateObservable extends Observable { private int data; public UpdateObservable(Observer observer) {
addObserver(observer);
/*
* add other observer
*/
} public int getData() {
return data;
} public void setData(int data) {
if (data != this.data) {
this.data = data;
setChanged(); //标记 改变, 仅仅有标记后才干通知到
notifyObservers(); //通知
} } @Override
public synchronized void addObserver(Observer o) {
super.addObserver(o);
} @Override
public synchronized void deleteObserver(Observer o) {
super.deleteObserver(o);
} @Override
public void notifyObservers() {
super.notifyObservers();
} @Override
public void notifyObservers(Object arg) {
super.notifyObservers(arg);
} @Override
public synchronized void deleteObservers() {
super.deleteObservers();
} @Override
protected synchronized void setChanged() {
super.setChanged();
} @Override
protected synchronized void clearChanged() {
super.clearChanged();
} @Override
public synchronized boolean hasChanged() {
return super.hasChanged();
} @Override
public synchronized int countObservers() {
return super.countObservers();
} }
/**
* 观察者 实现 java.util.Observer接口
* @author stone
*
*/
public class UpdateObserver implements Observer { @Override
public void update(Observable o, Object arg) {
System.out.println("接收到数据变化的通知:");
if (o instanceof UpdateObservable) {
UpdateObservable uo = (UpdateObservable) o;
System.out.print("数据变更为:" + uo.getData());
}
} }

2. 自己定义的观察模型

类图

/**
* 抽象观察者 Observer
* 观察 更新
* @author stone
*
*/
public interface IWatcher {
/*
* 通知接口:
* 1. 简单通知
* 2. 观察者须要目标的变化的数据,那么能够将目标用作參数, 见Java的Observer和Observable
*/
// void update(IWatched watched); void update(); }
/**
* 抽象目标 Subject
* 提供注冊和删除观察者对象的接口, 及通知观察者进行观察的接口
* 及目标 自身被观察的业务的接口
* @author stone
*
*/
public interface IWatchedSubject { public void add(IWatcher watch); public void remove(IWatcher watch); public void notifyWhatchers(); public void update();//被观察业务变化的接口
}
/**
* 详细观察者 Concrete Observer
*
* @author stone
*
*/
public class UpdateWatcher implements IWatcher { @Override
public void update() {
System.out.println(this + "观察到:目标已经更新了");
} }
/**
* 详细目标角色 Concrete Subject
* @author stone
*
*/
public class UpdateWatchedSubject implements IWatchedSubject {
private List<IWatcher> list; public UpdateWatchedSubject() {
this.list = new ArrayList<IWatcher>();
} @Override
public void add(IWatcher watch) {
this.list.add(watch);
} @Override
public void remove(IWatcher watch) {
this.list.remove(watch);
} @Override
public void notifyWhatchers() {
for (IWatcher watcher : list) {
watcher.update();
}
} @Override
public void update() {
System.out.println("目标更新中....");
notifyWhatchers();
} }

监听器是观察者的一种实现

类图

/**
* 监听 用户在注冊后
* @author stone
*
*/
public interface IRegisterListener {
void onRegistered();
}

/**
* 监听 当用户登录后
* @author stone
*
*/
public interface ILoginListener {
void onLogined();
}
/*
* 监听器 是观察者模式的一种实现
* 一些须要监听的业务接口上加入 监听器,调用监听器的对应方法,实现监听
*/
public class User { public void register(IRegisterListener register) {
/*
* do ... register
*/
System.out.println("正在注冊中...");
//注冊后
register.onRegistered();
} public void login(ILoginListener login) {
/*
* do ... login
*/
System.out.println("正在登录中...");
//登录后
login.onLogined();
} }
/**
* 观察者(Observer)模式 行为型模式
* 观察者模式定义了一种一对多的依赖关系,让多个观察者对象同一时候观察某一个目标对象。
* 这个目标对象在状态上发生变化时,会通知全部观察者对象,让它们可以自己主动更新自己
* 目标对象中须要有加入、移除、通知 观察者的接口
*
* @author stone
*/
public class Test { public static void main(String[] args) {
/*
* 使用Java自带的Observer接口和Observable类
*/
UpdateObservable observable = new UpdateObservable(new UpdateObserver());
observable.setData(99);
System.out.println("");
System.out.println("");
/*
* 自己定义的观察者模型
*/
IWatchedSubject watched = new UpdateWatchedSubject();
watched.add(new UpdateWatcher());
watched.add(new UpdateWatcher());
watched.update();
System.out.println(""); /*
* 子模式-监听器
*/ User user = new User();
user.register(new IRegisterListener() { @Override
public void onRegistered() {
System.out.println("监听到注冊后。。。");
}
});
user.login(new ILoginListener() { @Override
public void onLogined() {
System.out.println("监听到登录后。。。");
}
}); }
}

打印

接收到数据变化的通知:
数据变更为:99 目标更新中....
observer.UpdateWatcher@457471e0观察到:目标已经更新了
observer.UpdateWatcher@5fe04cbf观察到:目标已经更新了 正在注冊中...
监听到注冊后。。。
正在登录中...
监听到登录后。。。

Java 实现观察者(Observer)模式的更多相关文章

  1. Java设计模式之从[星际争霸的兵种升级]分析观察者(Observer)模式

    观察者模式定义对象的一种一对多的依赖关系.当一个对象的状态发生改变时.全部依赖于它的对象都会得到通知并被自己主动更新. 一个简单的样例是.在星际争霸的虫族中有一个0基础单位叫做跳狗(Zergling) ...

  2. 观察者(Observer)模式

    观察者模式又叫做发布-订阅模式(Publish.Subscribe)模式.模型-视图模式(Model/View)模式.源-监听器模式(Source/Listener)模式或从属者(Dependents ...

  3. 设计模式C++描述----04.观察者(Observer)模式

    一. 概述 Observer 模式要解决的问题为:建立一个一(Subject)对多(Observer)的依赖关系,并且做到当“一”变化的时候,依赖这个“一”的多也能够同步改变. Sbuject 相当于 ...

  4. java观察者(Observer)模式

    观察者模式:     试想,在电子商务网站上,一个用户看中了一件一份,但是当时衣服的价格太贵,你需要将衣服收藏,以便等衣服降价时自动通知该用户.这里就是典型的观察模式的例子.     1.观察者模式的 ...

  5. Java观察者模式(Observer模式)

    Java深入到一定程度,就不可避免的碰到设计模式(design pattern)这一概念,了解设计模式,将使自己对java中的接口或抽象类应用有更深的理解.设计模式在java的中型系统中应用广泛,遵循 ...

  6. 面向对象设计模式——观察者(OBSERVER)模式

    定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新.  Observer模式描述了如何建立这种关系.这一模式中的关键对象是目标(subject ...

  7. 设计模式之观察者(OBSERVER)模式

    定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新.  Observer模式描述了如何建立这种关系.这一模式中的关键对象是目标(subject ...

  8. Head First 设计模式 —— 02. 观察者 (Observer) 模式

    思考题 在我们的一个实现中,下列哪种说法正确?(多选) P42 public class WeatherDate { // 实例变量声明 public void measurementsChanged ...

  9. 《Head First 设计模式》ch.2 观察者(Observer)模式

    观察者模式 定义了对象之间一对多以来,这样一来,当一个对象改变状态时,它所有的依赖者都会收到通知并自动更新 设计原则-松耦合 松耦合将对象之间的互相依赖降到了最低——只要他们之间的接口仍被遵守 观察者 ...

随机推荐

  1. python写的屏保程序

    __author__ = 'ChenYan' from random import randint from tkinter import * class Randball(): def __init ...

  2. Android学习笔记:FrameLayout布局基础

    FrameLayout布局的特点是:所有放在布局里的视图组件,都按照层次堆叠在屏幕的左上角,后面的视图组件覆盖前面的. 当然,组件本身是可以控制自己的内部布局的. 一种常见的场景是可以在FrameLa ...

  3. CCIE路由实验(3) -- BGP高级部分

    当一个AS包含多个IBGP对等体时,路由反射器非常有用.因为IBGP客户只需要和路由反射器建立邻居关系,从而降低了IBGP的连接数量.路由反射器和它的客户合称为一个簇.路由反射是克服IBGP水平分割的 ...

  4. C#操作Excel(读/写)

    http://www.cnblogs.com/litianfei/archive/2008/03/21/1116906.html 写的很详细 一.操作Excel 首先导出Excel (1)示例: // ...

  5. 【转】关于C语言生成不重复的随机数

    一 说起随机函数,恐怕又有人说这是老生长谈了……一般很多人都形成了自己的固定格式,因为随机数用处比较大,用的时候比较多,拿过来就用了.但是新手不这么 干,他们总是抱有疑惑,我就是一个新手,而且较菜…… ...

  6. 找球号(一)(hask表)

    找球号(一) 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 在某一国度里流行着一种游戏.游戏规则为:在一堆球中,每个球上都有一个整数编号i(0<=i<= ...

  7. 多个线程怎样操作同一个epoll fd

    自己曾经做一个接口server时候,这样的场景下我的设计是多个线程操作同一个epoll fd.彼时,我的理由是epoll的系列函数是线程安全的. 当然有人不理解为什么会有多个线程操作同一个epoll ...

  8. iOS图片拉伸技巧-李明杰分享

    http://bbs.itcast.cn/thread-21436-1-1.html 本文目录 "一.iOS5.0之前------------------------------------ ...

  9. QTableWidget排序问题

    今天写代码,发现Qt4中QTableWidget显示查询结果数据时存在一个问题,具体原因不知道是用法不对还是QTableWidget本身存在的bug.现象如下: 1.      查询,能正常显示查询结 ...

  10. svn回滚版本2

    svn 版本回滚 取消对代码的修改分为两种情况:   第一种情况:改动没有被提交(commit). 这种情况下,使用svn revert就能取消之前的修改. svn revert用法如下: # svn ...