- 浏览: 564382 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (344)
- ··············未分类············· (33)
- Eclipse 插件 (15)
- EDA 工具 (1)
- Linux/Unix (3)
- Java (43)
- Java Applet (1)
- Java Draw2d (22)
- Java Draw2d version2 (6)
- Java GEF (2)
- Java SWT (21)
- Java SWT Image 图像 (21)
- Java SWT Tree (16)
- Java SWT Table (4)
- Java SWT TableViewer (11)
- Java SWTbot (4)
- Java Test (2)
- Java Thread 多线程 (22)
- Java Zest (5)
- RC2_3S400学习笔记 (16)
- tcl 脚本 (10)
- Verilog (7)
- XML (6)
- 国家 (5)
- 感叹 (4)
- 面试题 (9)
- 生活 (36)
- 足球 世界杯 (8)
- 老公看你的 (3)
- web开发 (1)
- 数据结构——图 (7)
- c language (1)
最新评论
-
zxjlwt:
路过素人派http://surenpi.com
SWT 树的事件 SWT.Selection SWT.CHECK SWT.DefaultSelection -
hj01kkk:
1楼用法正解
JDK 7 中的 Fork/Join 模式 -
fish_no7:
使用 new SortTask().fork()
JDK 7 中的 Fork/Join 模式 -
wpf523:
mark
Java 多线程例子6 线程安全 线程同步 同步代码块 同步函数 -
uniquejava:
以前碰到过,估计是在icu包中实现了双击自动选中一段文本的功能 ...
java.lang.NoClassDefFoundError: com/ibm/icu/text/BreakIterator
Java 提供了 Observer 模式的默认实现,下面我们就看一下 Java 对 观察者模式的支持。
Java 对 观察者模式的支持 主要体现在 Observable 类和 Observer 接口。
(1) Observable 类代表 被观察者 (java.util.Observable )
主要方法有:
void setChanged() : 设置被观察者的状态已经被改变
void addObserver(Observer observer) : 添加观察者
int countObservers() : 返回所有观察者的数目
void deleteObserver(Observer observer) :删除指定观察者
void deleteObservers() : 删除所有观察者
boolean hasChanged() : 被观察者的状态是否被改变,如果是则返回true,否则返回false
void notifyObservers() : 通知所有观察者(没有参数)
void notifyObservers(Object arg) : 通知所有观察者(带参数,参数一般设定为被改变的属性)
void clearChanged() :清除被观察者状态的改变(即调用 hasChanged() 时会返回 false)
(2) Observer 接口代表 观察者 (java.util.Observer )
它只有一个抽象方法需要被具体的观察者类实现(很重要 ):
void update(Observable observable, Object arg) :当 被观察者 调用 notifyObservers(*) 方法
时,会根据被观察者的 hasChanged() 方法 来判断 它的状态是否被改变, 如果被观察者的状态被改变了,则
会调用 观察者 的 update 方法,参数 observable 为 被观察者对象, arg 为调用 notifyObservers( Object arg ) 时传入的参数 arg ,如果调用的是 notifyObservers() 方法, 则 arg 为 null( 注意 :应该把这个参数 arg 设定为 被观察者的 被改变的属性)。
简单的例子:
public class MyObservable extends Observable { String info = "something happened !! "; public MyObservable () { // add observer 1 this.addObserver( new Observer() { public void update(Observable o, Object arg) { System.out.println("Observer 2 updated for <"+info+">"); System.out.println("Observer 1 updated!"); System.out.println("Observable is <" + o + ">"); System.out.println("Object is <" + arg + ">"); } }); // add observer 2 this.addObserver(new Observer() { // 自己实现一个 Observer public void update(Observable o, Object arg) { System.out.println("Observer 2 updated!"); System.out.println("Observable is <" + o + ">"); System.out.println("Object is <" + arg + ">"); } }); } public static void main(String[] args) { MyObservable obs = new MyObservable(); obs.setChanged(); obs.notifyObservers(); System.out.println("======================================="); obs.addObserver(new Observer() { // 自己实现一个 Observer public void update(Observable o, Object arg) { System.out.println("Observer 3 updated"); System.out.println("Observable is <" + o + ">"); System.out.println("Object is <" + arg + ">"); } }); obs.setChanged(); obs.notifyObservers(obs.info); } }
运行结果:
Observable is <P1.MyObservable@10b30a7>
Object is <null>
Observer 2 updated for <something happened !! >
Observer 1 updated!
Observable is <P1.MyObservable@10b30a7>
Object is <null>
=======================================
Observer 3 updated
Observable is <P1.MyObservable@10b30a7>
Object is <something happened !! >
Observer 2 updated!
Observable is <P1.MyObservable@10b30a7>
Object is <something happened !! >
Observer 2 updated for <something happened !! >
Observer 1 updated!
Observable is <P1.MyObservable@10b30a7>
Object is <something happened !! >
开始是没有参数的notify,后面是有参数的notify。
该模式适用的场景:这里有两个角色,一个是观察者,一个是被观察者,观察者是一个抽象的类,也就是要是继承这个类,具体类就不能够实现别的类了。观察者也是比较的简单只要实现一个update的方法,这个方法得到两个参数,第一参数是被观察者,第二个参数是被观察者传替的一个参数,notifyObservers(obs.info);,这个方法传入的。这样我们就可以想一下了,也就是,一个观察者,可以观察多个【被观察者】,然后观察者可以再update中区别是不同的【被观察者】发出的notify,同时也可以查看【被观察者】所传替的状态,来判断自己所要执行的操作了。【被观察者】这个角色是非常重要的,【被观察者】其实是一个管理者的角色,它可以增加观察者,删除观察者,通知事件的发生,通知事件的状态【通过参数】。
如打麻将例子:棋牌室是管理者,也就是【被观察者】,这个棋牌室有一些固定的会员,也就是观察者,在棋牌室有注册,也就是在【被观察者】中添加为了观察者,棋牌室到了下午,常常的麻将时间了,notifyObservers(),通知所有的会员,也就是打麻将的时间到了,有时间就来打麻将吧。a、b、c、d、e、f都是这里的会员,都收到了这个通知,a、b、c增好今天有时间就立刻去了,打麻将要4个人才好打,去早了要等,d比较的滑头,收到一开始的通知没有去,因为它知道棋牌室在每次去人之后,还会发出通知notifyObservers(3),这时候通知是有参数的,也就是说已经来了3个人,d收到这个通知,立刻就去棋牌室打牌了。a、b、c也会收到这样的通知,但这个时候他们已经到棋牌室了,就不在响应棋牌室的事情了,也可以理解为,我已经响应了。e、f在家带孩子,棋牌室的通知,知道了,也不响应。
多【被观察者】,引申上面的例子:a、b、c、d收到棋牌室的通知,打牌去,但是他们还是会相应别的事件的,如c,家里是有小孩的,老婆周末在家看着小孩,他出来打牌了,老婆突然接到妈妈的电话,要晚上过来吃饭,于是乎,立刻通知c,回来的带孩子,自己要去买菜,于是,c回去了。这个c观察【棋牌室】也观察【老婆的指示】
【被观察者】链,引申上面的例子:【被观察者】可以同时又是别的观察者,如上面棋牌室,是麻将们的【被观察者】,棋牌室这种的行为啊,有时候,警察要去看看,有没有巨赌,有赌娱乐就算了,不管怎样,棋牌室还是比较的怕警察的检查,于是这条街上面的棋牌室A、B、C就说,我一人出50元,给街头卖报纸的小赵,赵看到警察到街头了,赵就电话通知A、B、C,警察来了。A、B、C赶快让赌徒们收起大钞,1毛2毛娱乐
注意:
1,【被观察者】是线程安全的。
2,
发表评论
-
异常Exception
2014-08-15 14:22 0有三种基本的异常类。 Error用于Java虚拟机报告系 ... -
hashmap的简单实现
2014-08-15 14:20 709来自Thinking In Java【P493】。 Ja ... -
hashcode的实现
2014-08-15 14:18 732ThinkinJava中给出了Effective Java的 ... -
验证Hashmap不支持同步,ConcurrentHashMap支持
2014-08-15 14:14 969一直都不知道concurrenthashmap有什么实际的用 ... -
Java 中的嵌套类可以访问Private
2014-07-18 10:54 611注意:Java中的嵌套类与C++中的嵌套类大致一致,只不过C ... -
简单的递归转非递归例子 Fibonacci
2014-07-11 14:41 811package org.vocano.java.tst.re ... -
Java中的缓存
2014-07-10 15:48 644原文链接:http://blog.sina.com.cn/s ... -
快速随机访问和可删除的数组
2014-06-06 16:03 613原文链接:http://www.blogjava.net/q ... -
广度优先 深度优先访问 树
2014-06-06 15:37 656public class Tst { sta ... -
类语句块
2014-03-31 15:49 545public class Snippet extends s ... -
字符串不同,hashcode可以相同
2014-03-31 15:22 739public class Snippet { publi ... -
基本的小程序
2014-03-25 14:45 752斐波那契数列。(Fibonacci) public cla ... -
Java中hashCode和equals方法的正确使用
2014-02-19 11:28 726面试题:新建一个类,这个类要作用hashmap的键值,问需要 ... -
一个字符串在另一个字符串中出现的次数
2013-12-13 17:09 685一个字符串在另一个字符串中出现的次数 pub ... -
Java hashcode
2013-09-25 16:19 748原文:http://www.ibm.com/develope ... -
java 没有无符号整数
2013-09-02 17:09 948由于Java的原始类型里没有无符号类型,如果你需要某个宽度的 ... -
数组操作
2013-06-24 16:28 6691 数组倒叙:Snippet181 写道 int[] ... -
write object, read object 不一定比自己parse快速,只是简单,可以扩展好
2013-05-13 17:19 778write object, read object 不一定比 ... -
java.lang.IllegalStateException
2013-04-17 18:34 1143在使用iterator的remove的时候出现了java.la ... -
函数返回值
2013-04-17 18:15 789现在代码的水平还是 ...
相关推荐
首先,我们来看"Java设计模式——观察者模式的两种情况": 1. **主动通知**: 在这种情况下,被观察者对象在自身状态发生变化时,会主动调用`Observable`接口提供的`notifyObservers()`方法,将变化通知给所有注册的...
简单易懂的观察者模式
在《设计模式实现——观察者模式》这篇博客中,作者可能详细解释了观察者模式的概念、结构以及其在实际编程中的应用。以下是对观察者模式的详细阐述: 1. **模式定义**:观察者模式是一种对象行为型模式,它允许...
本文将深入探讨一种常用的设计模式——观察者模式(Observer Pattern),并结合Android实际应用给出实例解析。 观察者模式是一种行为设计模式,它定义了对象之间的一对多依赖关系,当一个对象的状态发生改变时,...
行为型模式主要关注对象间职责的分配和通信,包括责任链模式、命令模式、解释器模式、迭代器模式、备忘录模式、观察者模式、状态模式、策略模式、模板方法模式和访问者模式。这些模式有助于我们更好地管理对象的行为...
本文将深入探讨其中的一种——观察者模式(Observer Pattern)。观察者模式是一种行为设计模式,它定义了对象之间的一对多依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并自动更新。 ### ...
3. **观察者模式**:定义对象之间的一对多依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并自动更新。在事件驱动编程中广泛使用,例如GUI组件间的交互。 4. **装饰器模式**:动态地给一个...
在本文中,我们将深入探讨设计模式中的一个经典案例——观察者模式(Observer Pattern),通过具体的实现来理解其工作原理。观察者模式是一种行为设计模式,它定义了对象之间的一对多依赖关系,当一个对象的状态发生...
《设计模式——观察者》 在软件工程中,设计模式是一种在特定情境下解决常见问题的经验总结,它们是经过反复验证的最佳实践。观察者模式(Observer Pattern)是行为设计模式的一种,它定义了对象之间的一对多依赖...
本文将深入探讨其中的一种——观察者模式(Observer Pattern),它是行为设计模式的一种,主要用来封装行为的变化,实现对象间一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并被...
观察者模式定义了对象之间的一对多依赖关系,当一个对象的状态改变时,所有依赖于它的对象都会得到通知并被自动更新;状态模式允许一个对象在其内部状态改变时改变它的行为,看起来它好像修改了它的类;策略模式定义...
从中,我们就可以得出观察者模式的定义。 观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,这个主题对象在状态发生变化时,会通知所有观察者对象,使它们能够自动更新自己的行为...
观察者模式(Observer Pattern)是设计模式中的一种行为模式,它定义了对象之间的一对多依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并自动更新。这种模式在软件开发中广泛应用于事件驱动...
### 设计模式——观察者模式详解 #### 一、引言 在软件工程领域,设计模式是一种被广泛采用的方法论,用于解决常见的编程问题。本文将深入探讨《设计模式(极力推荐)》这本书中提到的一个关键模式——观察者模式。...
《设计模式——Java语言中的应用》是一本专为Java开发者深入理解面向对象设计而编写的经典书籍。设计模式是软件工程领域中经过实践验证的、解决常见问题的有效方案,它们代表了在特定上下文中,针对特定问题的最优...
在描述中提到的“老鼠和猫”的对象问题,可能是指经典的设计模式——观察者模式(Observer Pattern)。在这种情况下,猫(Subject)是被观察者,老鼠(Observers)是观察者。当猫的状态发生变化(例如位置或状态更新...
在本文中,我们将深入探讨设计模式中的"观察者模式",并以`WeatherData`为例进行具体实现。观察者模式是一种行为设计模式,它允许我们定义一个订阅机制,当对象状态发生变化时,可以通知所有依赖它的观察者。这种...