本文实例讲述了Java内置观察者模式。分享给大家供大家参考,具体如下:
之前也简单地写过观察者模式(又称为发布-订阅模式)小例子,现在项目中也常用到该模式。今天贴一下如何使用Java内置的观察者模式。
主要使用到的Java API就两个类:
Observer接口:观察者对象,监听被观察者对象数据变化,一是数据发生变化 ,就做出相应地啥响应。
Observable类:被观察者对象,提供添加及移出观察者对像方法,数据发生哟完成时并通知所有已经添加进来的观察者对象。
被观察者代码示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
//Observable是被观察者对象接口,实现该接口就是:目标(被观察者)的具体实现
public class TargetObservable extends Observable {
// 要观察的数据:消息发生改变时,所有被添加的观察者都能收到通知
private String message;
public String getConent() {
return message;
}
public void setMessage(String message) {
this .message = message;
// 被观察者数据发生变化时,通过以下两行代码通知所有的观察者
this .setChanged();
this .notifyObservers(message);
}
}
|
2个观察者代码示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
//Observer对象是观察者,实现Observer的对象就是具体的观察者对象
public class TargetObserver implements Observer {
// 定义观察者名称
private String name;
public String getObserverName() {
return name;
}
public void setObserverName(String observerName) {
this .name = observerName;
}
@Override
public void update(Observable arg0, Object arg1) {
//更新消息数据
System.out.println(name + "收到了发生变化的数据内容是:"
+ ((TargetObservable) arg0).getConent());
}
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
public class TargetObserver01 implements Observer {
// 定义观察者名称
private String name01;
public String getObserverName() {
return name01;
}
public void setObserverName(String observerName) {
this .name01 = observerName;
}
@Override
public void update(Observable arg0, Object arg1) {
//更新消息数据
System.out.println(name01 + "收到了发生变化的数据内容是:"
+ ((TargetObservable) arg0).getConent());
}
}
|
测试代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/**
* @description:测试类
* @author ldm
* @date 2016-11-1 上午8:29:07
*/
public static void main(String[] args) {
// 创建一个具体的被 观察者
TargetObservable observable = new TargetObservable();
// 创建第一个观察者
TargetObserver one = new TargetObserver();
one.setObserverName( "我是观察者A" );
// 创建第二个观察者
TargetObserver01 two = new TargetObserver01();
two.setObserverName( "我是观察者B" );
// 注册观察者
observable.addObserver(one);
observable.addObserver(two);
// 目标更新天气情况
observable.setMessage( "***我要更新的数据***" );
}
}
|
执行结果:
1
2
|
我是观察者B收到了发生变化的数据内容是:—–我要更新的数据—–
我是观察者A收到了发生变化的数据内容是:—–我要更新的数据—–
|
模式优点:
一个被观察者可以对应多个观察者,当被观察者发生变化的时候,他可以将消息通知给所有已经添加观察者。基于接口实现为程序提供了更大的灵活性。
但在使用时要注意根据条件及时添加或移除观察者对象,否则可能导致意料外结果 。
最后附上Observer和Observable的原码,这样我们自己在写的时候就知道如何下手了:
1
2
3
4
5
|
package java.util;
import java.util.Observable;
public interface Observer {
void update(Observable var1, Object var2);
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
package java.util;
import java.util.Observer;
import java.util.Vector;
public class Observable {
private boolean changed = false ;
private Vector<Observer> obs = new Vector();
public Observable() {
}
public synchronized void addObserver(Observer var1) {
if (var1 == null ) {
throw new NullPointerException();
} else {
if (! this .obs.contains(var1)) {
this .obs.addElement(var1);
}
}
}
public synchronized void deleteObserver(Observer var1) {
this .obs.removeElement(var1);
}
public void notifyObservers() {
this .notifyObservers((Object) null );
}
public void notifyObservers(Object var1) {
Object[] var2;
synchronized ( this ) {
if (! this .changed) {
return ;
}
var2 = this .obs.toArray();
this .clearChanged();
}
for ( int var3 = var2.length - 1 ; var3 >= 0 ; --var3) {
((Observer)var2[var3]).update( this , var1);
}
}
public synchronized void deleteObservers() {
this .obs.removeAllElements();
}
protected synchronized void setChanged() {
this .changed = true ;
}
protected synchronized void clearChanged() {
this .changed = false ;
}
public synchronized boolean hasChanged() {
return this .changed;
}
public synchronized int countObservers() {
return this .obs.size();
}
}
|
希望本文所述对大家java程序设计有所帮助。